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E-MAIL SOFTWARE AND METHOD AND SYSTEM FOR 
DISTRIBUTING ADVERTISEMENTS TO CLIENT DEVICES 
THAT HAVE SUCH E-MAIL SOFTWARE INSTALLED THEREON 

COPYRIGHT NOTICE 

[0001] A portion of the disclosure of this patent document contains material which is 

subject to copyright protection. The copyright owner has no objection to the facsimile 
reproduction by any one of the patent document or patent disclosure as it appears in the 
Patent and Trademark Office patent file or records, but otherwise reserves all copyright 
rights whatsoever. 

BACKGROUND OF THE INVENTION 

[0002] The present invention relates generally to the field of electronic mail ("e-mail") 

software and systems. More particularly, the present invention is related to advertiser- 
supported e-mail software for delivering advertisements to client computers having this 
advertiser-supported e-mail software installed thereon. 

[0003] This application is based on Provisional Patent Application No. 60/169,622, 

which was filed on December 8, 1999. This Provisional Patent Application is 
incorporated herein by reference in its entirety. 

[0004] Electronic mail ("e-mail") has become a ubiquitous form of communication in 

recent years. In general, e-mail works as follows. E-mail software is installed on a 
client device, e.g., a personal computer (PC), equipped or configured for 
communications with a multiplicity of other client devices via a communications 
network. Access to the communications network can be provided by a communications 
network service provider, e.g., an Internet Service Provider (ISP) and/or a proprietary 
network e-mail service provider, with whom the user establishes one or more e-mail 
accounts, each identified by a unique e-mail address, e.g., president@whitehouse.gov. 
The e-mail software, e.g., the e-mail client, enables a user of the client device to 
compose e-mail messages, to send e-mail messages to other client devices via the 
communications network, and to read e-mail messages received from other client 
devices via the communications network. A user can send e-mail messages to multiple 
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recipients at a time, which capability is sometimes referred to using a mailing list or, in 
extreme cases, bulk mailing. The typical e-mail client supports Post Office Protocol 
Version 3 (POP3), Simple Mail Transfer Protocol (SMTP), Internet Mail Access 
Protocol, Version 4 (IMAP4), and/or Multipurpose Internet Mail Extensions (MIME). 
[0005] Each ISP and each proprietary network e-mail service provider independently 

operates and controls an e-mail communication system (or, simply, "e-mail system"). 
These independently-operated e-mail systems are bi-directional store-and-forward 
communication systems that are interconnected to one another via the Internet. Each e- 
mail system generally includes a number of e-mail servers that store inbound and 
outbound e-mail messages and then forward them, route them, or simply make them 
available to the users/intended recipients. Different e-mail systems are operated and 
controlled by independent control entities. With the advent of the Internet, the user is 
not restricted to a single system providing both an incoming e-mail server (or server 
cluster) and an outgoing e-mail server (cluster), i.e., both the incoming and outgoing e- 
mail servers under the control of a single entity. Most e-mail clients, other than 
proprietary e-mail systems such as AOL and JUNO, can be configured to receive e-mail 
from an incoming e-mail server (cluster) controlled by a first entity and an outgoing 
email server (cluster) controlled by a second, totally independent entity. It will be 
appreciated that most casual email users download from and upload to respective 
servers operated by a single entity. 
[0006] Generally, when a user desires to send e-mail messages, or to check for received 

messages (which operations can occur automatically according to a prescribed 
schedule), the e-mail software is activated. Upon being activated, the e-mail software: 
[0007] • effects a connection or communications session with the host ISP or e-mail 

service provider via a prescribed communication link by invoking a prescribed 

communications mechanism, e.g., a dial-up modem, an ISDN connection, a DSL 

or ADSL connection, etc.; 
[0008] • electronically transmits or transports any e-mail messages desired to be sent to 

the e-mail server system operated by the host ISP or e-mail service provider, 

e.g., via an SMTP server; 
[0009] • receives any inbound e-mail messages forwarded to the client device by the host 

ISP or e-mail service provider, e.g., via a POP3 or IMAP4 server; and 
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[0010] stores any received e-mail messages in a prescribed memory location within the 

client device, e.g., at either the default location established by the e-mail client or 
a user-selected location. 

[0011] Exemplary e-mail software is the commercially available e-mail software 

marketed by the present assignee, QUALCOMM INCORPORATED, under the 
registered trademarks EUDORA PRO® and EUDORA LIGHT® (hereinafter 
sometimes referred to generically as "Eudora"). In general, the EUDORA PRO e-mail 
software provides the user with a "full feature set," and the EUDORA LIGHT e-mail 
software provides the user with a "reduced feature set" that is a subset of the "full 
feature set" provided by the EUDORA PRO e-mail software. The EUDORA PRO e- 
mail software (the previous version of which is referred to as "EP4" in this document) 
must be paid for by the user (or by someone else on behalf of the user), and can thus be 
regarded as "Payware", whereas the EUDORA LIGHT e-mail software is provided free 
of charge to registered users, and thus, can be regarded as "Freeware." Each of the 
client devices that has any version of Eudora installed thereon can be regarded as a 
"Eudora client." Presently, there is a very large installed base of Eudora clients. 

[0012] The present assignee, QUALCOMM INCORPORATED, has recently released a 

new version of its popular EUDORA e-mail software that is popularly known as 
EUDORA Adware (hereinafter sometimes referred to simply as "Adware"). This new 
Adware version of Eudora is contained within, i.e., is an integral part of, a new Eudora 
software product that contains the previously-referenced Payware and Freeware 
versions of Eudora. In general, each version of Eudora contained within this Eudora 
product release constitutes a separate operating mode of a single software product. 
Advantageously, the Adware Version of Eudora Pro® can be activated or switched 
between modes either automatically, in accordance with prescribed criteria or 
conditions, or manually, in accordance with prescribed user actions, e.g., registration, 
payment, selection, etc. This new Adware version of Eudora and the multi-moded 
Eudora e-mail software product that contains the same were motivated by a desire on 
the part of the present assignee to provide users with the "full feature set" afforded by 
the Payware version of Eudora free of charge to the users, by means of distributing 
advertisements paid for by advertisers to Eudora clients, thereby effectively shifting the 
source of payment/revenue from the users to the advertisers. Thus, this new Eudora 
software product can be regarded as "advertiser-supported" or "advertiser-subsidized" or 
simply "sponsored" software. 
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[0013] Most Internet service providers (ISPs) and e-mail service providers charge users 

a flat monthly subscription fee, although some providers still charge users based on 
usage, e.g., additional charges for on-line time beyond a prescribed level. However, 
there exists a population of users who desire to have basic e-mail service, but who do 
not require or want to pay for Internet access. A few companies have addressed the 
needs of this market segment by providing free e-mail service to users/subscribers who 
agree to receive advertisements along with their received e-mail messages. In this way, 
the advertisers support or sponsor the free e-mail service. 

[0014] Based upon the relevant literature, it appears that the first company to propose 

and offer such a free e-mail service was FreeMark Communications (a.k.a. 
"ProductView Interactive"). The FreeMark system and method for providing free e- 
mail service is disclosed in PCT published patent application International Publication 
Number WO 96/24213, having a priority date of February 1, 1995, based on U.S. 
Application Serial Number 08/382,118, naming as inventors Marv Goldschmitt and 
Robert A. Young. The disclosure of this published PCT patent application is expressly 
incorporated herein by reference. In short, this free e-mail system was subsidized by 
advertisers that appended advertisements as attachments, e.g., graphical interchange 
format (GIF) image file attachments, to e-mail messages transmitted to subscribers. The 
advertisements were stored on the subscriber's computer for viewing while the 
subscriber was off-line reading the received e-mail messages. In some of their 
promotional literature, FreeMark referred to the appended advertisements as "postage 
stamps". In FreeMark' s literature, each message received by the subscriber was 
depicted as an envelope bearing a postage stamp; the postage stamp was the 
advertisement. 

[0015] Subsequently, a company by the name of Juno Online Services, L.P. (hereinafter 

simply "JUNO") introduced a free e-mail service. The JUNO system and method for 
providing free e-mail service is disclosed in U.S. Patent Number 5,809,242, which 
issued to Marsh et al. on December 8, 1998, the disclosure of which is also expressly 
incorporated herein by reference. With the proprietary JUNO e-mail system, a plurality 
of advertisements are downloaded to subscribers when they connect to the proprietary 
JUNO e-mail server system to send and/or receive e-mail messages, with the 
advertisements being stored locally on the subscriber's computer for display when the 
subscriber is off-line composing or reading e-mail messages, i.e., when the subscriber 
activates Juno e-mail software previously installed on the subscriber's computer. The 
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locally stored advertisements are displayed under the control of a display scheduler 
resident on the subscriber's computer, to thereby enable the advertisements to be rotated 
or changed in a dynamic manner. This results in a continuously-changing display of 
advertisements being presented to the subscriber. Various other aspects and features of 
the proprietary JUNO e-mail system are disclosed in U.S. Patent Number 5,838,790, 
which issued to McAuliffe et al on November 17, 1998, and in U.S. Patent Number 
5,848,397, which issued to Marsh et al on December 8, 1998; the disclosures of both of 
these patents are also expressly incorporated herein by reference. 

[0016] With both the FreeMark and JUNO proprietary free e-mail systems, both the 

advertisements and the e-mail messages are stored on a single e-mail system (e.g., 
JUNO stores both on a single, unique server which is assigned (bound) to the user when 
he/she first signs up for service), and are distributed to subscribers under the direction of 
a common control entity that is controlling all part of the e-mail system. While this may 
be a desirable system architecture for providing free e-mail service, it is not a suitable 
system architecture for a system whose purpose is to distribute advertiser-supported e- 
mail software that is e-mail system-independent, i.e., which is not tied to a particular 
proprietary e-mail service provider but, rather, supports public standards, e.g., POP3, 
SMTP, IMAP4, etc. Moreover, the free e-mail system architecture is not suitable for 
the many people who maintain multiple e-mail accounts, e.g., business and personal e- 
mail accounts. As mentioned previously, the present inventors were motivated by a 
desire to provide a system and method for distributing advertisements to Eudora clients 
in order to generate advertising revenues that would allow a fully-featured version of the 
Eudora e-mail software to be widely distributed free of charge to end-users. Moreover, 
the present inventors were motivated by a desire to provide e-mail software that is both 
universal and e-mail system-independent, i.e., it is not tied to any particular proprietary 
e-mail service or service provider. 

[0017] Accordingly, the present inventors have developed a novel multi-moded Eudora 

e-mail software product that contains the Payware, Freeware and Adware, and have also 
devised a novel system and method for distributing advertisements to clients equipped 
with this new software product. As will become fully apparent hereinafter, the purpose 
and architecture of this novel system are radically different than that of the proprietary 
FreeMark and JUNO e-mail systems. In this regard, the multi-moded Eudora e-mail 
software product, and the novel system and method for distributing advertisements to 
clients equipped with this new software product, embraces a number of different 
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inventions that will become fully apparent from the following disclosure and the 
documents referenced therein. 



SUMMARY OF THE INVENTION 



[0018] Based on the above and foregoing, it can be appreciated that there presently 

exists a need in the art for a subsidized e-mail client which overcomes the above- 
described deficiencies. The present invention was motivated by a desire to overcome 
the drawbacks and shortcomings of the presently available technology, and thereby 
fulfill this need in the art. 

[0019] In one of its aspects, the present invention encompasses e-mail software which 

incorporates an automatic advertisement download function for automatically 
downloading advertisements to be displayed when the e-mail software is activated, for 
the purpose of subsidizing the full e-mail software product (e.g., to provide a 
"Freeware" version of the e-mail software product to end-users), wherein the e-mail 
software is e-mail system-independent. Preferably, the e-mail software is a stand-alone 
product which is universal, i.e., works in conjunction with virtually any e-mail service 
provider or e-mail system, including those service which comply with open standards. 
The present invention also encompasses a system and method for automatically 
distributing advertisements to a multiplicity of client devices which have this e-mail 
software installed thereon. 

[0020] According to another aspect, the present invention provides a recording medium 

storing e-mail client software for instantiating an e-mail client which receives e-mail 
messages from and sends e-mail messages to at least one of a plurality of e-mail servers 
operated by their respective e-mail operators, wherein the e-mail client automatically 
receives ads from an ad server which operates independent of the e-mail servers. 

[0021] According to still another aspect, the present invention encompasses a method of 

operating an e-mail client, provided by an ad server operator, compatible with a 
plurality of independently operated e-mail servers, including ones based on open e-mail 
standards. Preferably, the method includes steps for periodically at least one of sending 
and receiving e-mail from selected ones of the e-mail servers, periodically receiving ads 
from the ad server operator, and displaying the received ads responsive to instructions 
provided by the ad server operator. 
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[0022] According to a still further aspect, the present invention provides an e-mail 

system including an incoming e-mail server storing incoming e-mail messages 
addressed to a plurality of users, an outgoing e-mail server for forwarding or routing 
outgoing e-mail messages generated by the users, and an ad server operating 
independently of the e-mail server, and a plurality of e-mail clients operated by 
respective users. Preferably, each of the e-mail clients checks for respective e-mail 
messages stored on the incoming e-mail server, transmits any outgoing e-mail messages 
stored on the e-mail client to the outgoing e-mail server, and downloads available ads 
from the ad server while the e-mail client is online. 

[0023] In one aspect, the present invention provides software for use on a client device 

that is configured for communications with at least one remote source of advertisements 
via a communications network. Advantageously, the software instantiates an 
advertisement download function that downloads advertisements from the at least one 
remote source, during one or more advertisement download sessions, an advertisement 
storage function that stores the downloaded advertisements on a storage medium 
associated with the client device, an advertisement display function that effects display 
of at least selected ones of the stored advertisements on a display associated with the 
client device, an obscured ad monitor function that determines whether an obscured ad 
condition has occurred, whereby the obscured ad condition occurs when an 
advertisement currently being displayed on the display associated with the client device 
is being obscured by one or more other items currently being displayed on the display, 
and an obscured ad nag function that generates an obscured ad nag display in response 
to detection of the obscured ad condition, wherein the obscured ad nag display notifies 
the user of the obscured ad condition. 

[0024] In another aspect, the present invention provides software for use on a client 

device that is configured for communications with a multiplicity of other client devices 
via a communications network, wherein the software instantiates an e-mail composition 
function for enabling a user of the client device to compose e-mail messages, an e-mail 
send function that enables the user to send e-mail messages to other client devices via 
the communications network, an e-mail receive function that enables the user to receive 
e-mail messages from other client devices via the communications network, an 
advertisement download function that downloads advertisements from at least one 
remote source, during one or more advertisement download sessions, an advertisement 
storage function that stores the downloaded advertisements on a storage medium 
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associated with the client device, an advertisement display function that effects display 
of at least selected ones of the stored advertisements on a display associated with the 
client device, an obscured ad monitor function that determines whether an obscured ad 
condition has occurred, whereby the obscured ad condition occurs when an 
advertisement currently being displayed on the display associated with the client device 
is being obscured by one or more other items currently being displayed on the display, 
and an obscured ad nag function that generates an obscured ad nag display in response 
to detection of the obscured ad condition, wherein the obscured ad nag display notifies 
the user of the obscured ad condition. 

[0025] Many other features, aspects, uses, applications, advantages, modifications, 

variations, and alternative embodiments of the foregoing inventive concepts will 
become apparent from the technical documentation that follows. This technical 
documentation constitutes an integral part of this application for all purposes. 
Moreover, additional inventive concepts that have not been discussed above are 
disclosed in this technical documentation, and it is intended that this application cover 
such additional inventive concepts. 

[0026] Furthermore, certain terms that have been used in the foregoing and following 

descriptions of the present invention are defined as follows: 
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TERM 


DESCRIPTION 


Advertisement(s) 


This term is intended to broadly encompass any secondary content 
that is delivered or distributed to client devices in addition to the 
primary content, e.g., e-mail messages, which the software product 
instantiated by the client device is designed to receive, transmit, 
process, display, and/or utilize. For example, this term is intended 
to cover, without limitation, paid advertisements, community 
service messages, public service announcements, system 
information messages or announcements, cross-promo spots, 
artwork, and any other graphical, multimedia, audio, video, text, or 
other secondary digital content. Nevertheless, it will be recognized 
that the primary purpose of the presently contemplated commercial 
embodiment of the present invention is to distribute paid 
advertisements, and thus, in accordance with the preferred 
embodiment of the present invention, the advertisements will be 
exclusively, or at least primarily, paid advertisements. 


Client Device 


This term is intended to broadly encompass any device that has 
digital data processing and output, e.g., display, capabilities, 
including, but not limited to, desktop computers, laptop computers, 
hand-held computers, notebook computers, Personal Digital 
Assistants (PDAs), palm-top computing devices, intelligent 
devices, information appliances, video game consoles, information 
kiosks, wired and wireless Personal Communications Systems 
(PCS) devices, smart phones, intelligent cellular telephones with 
built-in web browsers, intelligent remote controllers for cable, 
satellite, and/or terrestrial broadcast television, and any other 
device that has the requisite capabilities. 
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Information 


This term is intended to broadly encompass any intelligible form 
of information which can be presented by a client device, i.e., an 
information client device, including, without limitation, text, 
documents, files, graphical objects, data objects, multimedia 
content, audio/sound files, video files, MPEG files, JPEG files, 
GIF files, PNG files, HTML documents, applications, formatted 
documents (e.g., word processor and/or spreadsheet documents or 
files), MP3 files, animations, photographs, and any other 
document, file, digital, or multimedia content that can be 
transmitted over a communications network such as the Internet. 


E-mail Messages 


This term is intended to broadly encompass the e-mail message 
and any attachments thereto, including, without limitation, text, 
documents, files, graphical objects, data objects, multimedia 
content, audio/sound files, video files, MPEG files, JPEG files, 
GIF files, PNG files, HTML documents, applications, formatted 
documents (e.g., word processor and/or spreadsheet documents or 
files), MP3 files, animations, photographs, and any other 
document, file, digital, or multimedia content that can be 
transmitted over a communications network such as the Internet. 


Software 
Provider 


This term is intended to broadly encompass the developer (or 
developers), sellers, distributors, etc., of the multi-mode software 
products(s) installed on the client device. 


Memory 


This term is intended to broadly encompass any device capable of 
storing and/or incorporating computer readable code for 
instantiating the client device referred to immediately above. 
Thus, the term encompasses all types of recording medium, e.g., a 
CD-ROM, a disk drive (hard or soft), magnetic tape, and recording 
devices, e.g., memory devices including DRAM, SRAM, 
EEPROM, FRAM, and Flash memory. It should be noted that the 
term is intended to include any type of device which could be 
deemed persistent storage. To the extent that an Application 
Specific Integrated Circuit (ASIC) can be considered to 
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incorporate instructions for instantiating a client device, an ASIC 
is also considered to be within the scope of the term "memory." 



BRIEF DESCRIPTION OF THE DRAWINGS 

[0027] These and various other features and aspects of the present invention will be 

readily understood with reference to the following detailed description taken in conjunc- 
tion with the accompanying drawings, in which like or similar numbers are used 
throughout, and in which: 

[0028] Fig. 1 is a high-level diagram of a computer system including a plurality of 

client devices connected to a plurality of independently-operated server devices via a 
network, which computer system is suitable for implementing various functions 
according to the present invention; 

[0029] Fig. 2 is a high-level diagram of a representative one of the client devices 

illustrated in Fig. 1; 

[0030] Figs. 3A and 3B illustrate alternative and non-limiting placement of ads in the 

main navigation screen of an exemplary e-mail software application according to the 
present invention; 

[0031] Fig. 4A depicts state transitions when a version of the software is installed by 

one of a new user, an old user, and an EP4 user; 
[0032] Fig. 4B illustrates a dialog box associated with the state flow diagram illustrated 

in Fig. 4A; 

[0033] Fig. 5A illustrates an exemplary state flow diagram of a process by which the 

Ad user becomes a registered Ad user while Figs. 5B through 5G illustrate several 

dialog boxes associated with Fig. 5A; 
[0034] Fig. 6A illustrates an exemplary state flow diagram of a process by which a Free 

user can become a registered Free user while Fig. 6B illustrates an additional dialog box 

associated with Fig. 6A; 
[0035] Fig. 7A illustrates an exemplary state flow diagram of a process by which all 

users are reminded to update the software according to the present invention while Fig. 

7B depicts an exemplary dialog box corresponding to an Update Nag; 
[0036] Fig. 8 illustrates an exemplary state flow diagram of a process by which a Box 

user can become a Paid user; 
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[0037] Fig. 9 illustrates an exemplary state flow diagram of a process by which the Paid 

User becomes an Unpaid user; 
[0038] Fig. 10 illustrates an exemplary Nag Window display timeline for MacOS 

versions of the Eudora e-mail software according to an exemplary embodiment of the 

present invention; 

[0039] Fig. 11 illustrates a Nag Schedule employed by the software according to the 

present invention; 

[0040] Fig. 12A is a simulated screen capture of a link history window employed in an 

exemplary software embodiment of the present invention while Fig. 12B is a dialog box 
reminding the user that the e-mail client according to the present invention is off-line; 

[0041] Fig. 13A illustrates the assumptions used in determining the impact of ad 

transmission on e-mail program operations while Fig. 13B is a table listing the 
bandwidth requirements in terms of subscriber base versus the number of new ads to be 
downloaded each day; 

[0042] Fig. 14 is a state flow diagram of an exemplary ad fetch process according to the 

present invention; 

[0043] Figs. 15 A - 15H collectively illustrate an algorithm controlling ad scheduling in 

an exemplary embodiment according to the present invention; 
[0044] Figs. 16A and 16B illustrate parameter variations in alternative modes of ad 

display possible in an exemplary embodiment according to the present invention; 
[0045] Figs. 17A through 17C illustrate additional dialog boxes which advantageously 

can be generated by the e-mail client software according to one aspect of the present 

invention; 

[0046] Fig. 18A illustrates an exemplary dialog box associated with auditing the 

operation of the Adware software according to the present invention while Figs. 18B 
through 18E list useful parameters for auditing the software's performance; 

[0047] Fig. 19 is a table summarizing the features of a plurality of web pages that 

advantageously can be employed in conjunction with an exemplary e-mail system 
according to one aspect of the present invention; 

[0048] Fig. 20 is a class diagram illustrating the mapping of XML code to objects and 

the task flow when another exemplary embodiment according to the present invention is 
operating in accordance with doPost methodology; 
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[0049] Figs. 21A and 21B collectively constitute a pseudo code listing which can be 

employed by the server 302 in Fig. 1 in generating a PlayList in accordance with the 
present invention; 

[0050] Fig. 22 is another class diagram illustrating handling of requests and writes 

between a server and at least one of the client computers depicted in Fig. 1; and 

[0051] Fig. 23 illustrates database accesses in accordance with another aspect of the 

present invention. 

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 

[0052] Illustrative embodiments and exemplary applications will now be described with 

reference to the accompanying drawings to disclose the advantageous teachings of the 
present invention. 

[0053] While the present invention is described herein with reference to illustrative 

embodiments for particular applications, it should be understood that the invention is 
not limited thereto. Those having ordinary skill in the art and access to the teachings 
provided herein will recognize additional modifications, applications, and embodiments 
within the scope thereof and additional fields in which the present invention would be of 
significant utility. 

[0054] Referring now to specific drawings, Fig. 1 illustrates an exemplary system 

configuration 10 which is suitable for carrying out the functions according to 
representative embodiments of the present invention. Although the representative 
embodiment will be generally described with respect to an electronic mail (e-mail) 
system where a number of users can create, send, receive and read e-mail messages, the 
present invention is not so limited. For example, the present invention is equally 
applicable to a personal digital assistant (PDA) incorporating specialized software for 
receiving stock quotations via a wireless network. Thus, the principles of the present 
invention should not be regarded as limited solely to e-mail systems; the principles of 
the present invention apply to on-line services where a provider, e.g., a software 
provider, desires to make its software available to users using a variety of payment 
options for a core set of software functions. 

[0055] As shown in Fig. 1, the system 10 includes a plurality of client computers 100a, 

100b, lOOn, where n denotes any positive integer. Preferably, each of the client 
computers generally denoted 100 can be either a workstation or a personal computer 
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executing a client program according to the present invention. In an exemplary case, 
the client computers 100a, 100b, lOOn advantageously can be connected to a 
plurality of servers 301 - 304, which servers will be described in greater detail below, 
via a network 200, e.g., the Internet. Alternatively, the network 200 can be one of a 
local area network (LAN), a wide area network (WAN), an Intranet, or a wireless 
network, or some combination thereof. It will be appreciated that Fig. 1 illustrates a 
non-limiting exemplary system; and number of clients can be connected to any number 
of servers. 

[0056] Fig. 2 illustrates in further detail the hardware configuration of an exemplary one 

of the client computers 100a, 100b, lOOn illustrated in Fig. 1. In the representative 
embodiment, the client computer 100a includes a central processing unit 209 for 
executing computer programs (including the client program according to one exemplary 
embodiment of the present invention) and managing and controlling the operation of the 
client computer 100a. A storage device 205, such as a floppy disk drive, is coupled to 
the central processing unit 209 for, e.g., reading and writing data and computer 
programs to and from removable storage media such as floppy disks. Storage device 
206, coupled to the central processing unit 209, also provides a mechanism for storing 
computer programs and data. Storage device 206 is preferably a hard disk having a high 
storage capacity. A dynamic memory device 207 such as a RAM, is also coupled to the 
central processing unit 209. It will be noted that storage devices 205 and 206, as well as 
dynamic memory device 207, are non-limiting examples of a memory, which term was 
defined previously. The client computer 100a includes typical input/output devices, 
such as, for example, a keyboard 203, a mouse 204, a monitor 208, and a 
communications device 201. It will be appreciated that the communications device 
advantageously can be a modem, an ethernet interface card, etc. 

[0057] Referring again to Fig. 1, each of the client computers 100a, 100b, lOOn can 

selectively communicate with any of the servers, e.g., servers 301 - 304, via the 
network 200. In the computer system 10 depicted in Fig. 1, each of the servers 
performs a specialized function. In an exemplary case, server 301 performs a 
registration function, i.e., accepts registration information from each client computer (as 
discussed in greater detail below), server 302 provides PlayLists to the client computers 
100a, 100b, lOOn, server 303 provides the advertisements designated in the 
PlayLists, and server 304 acts as a conventional e-mail system server system, i.e., 
provides both the incoming e-mail server and the outgoing e-mail server. It should be 
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mentioned that only servers 301 and 302 need actually be under the direct control of the 
software provider, e.g., QUALCOMM INCORPORATED in the preferred embodiment, 
although server 303 advantageously may be under the control of the software provider 
as well. It should also be mentioned that the reference to software should not be 
construed as limited to disk based software; the term "software" should be broadly 
interpreted as instructions carried out by a processor, whether these instructions are read 
from a dynamic memory or stored as firmware in an read only memory (ROM) or other 
variants of such a device. 

[0058] According to one aspect of the present invention, the "software" advantageously 

can be provided as a single binary (per client device) file containing the software, e.g., 
the Eudora software, which can be employed by all users. This binary file will operate 
in one of three major modes of operation: Payware; Freeware; and Adware. In the 
Payware mode of operation, the user must pay the software provider to use the software. 
Freeware is free for all to use, but has fewer features than either Payware or Adware. 
Preferably, Payware users will prove their payment by a registration code that the 
software provider will provide to them at time of payment. This code will be self- 
validating, and contain enough data to identify what version(s) the user is entitled to 
operate. It should be noted that users of the Payware version of Eudora will be entitled 
to all versions of Eudora that are produced during the calendar year following their 
payment. The software preferably polls a predetermined site, e.g., a site maintained by 
QUALCOMM INCORPORATED, on a periodic basis in order to determine if an 
update for the software is available; if an update is available, the software 
advantageously can present the user with a small web page of options for obtaining the 
software update, as discussed in greater detail below. 

[0059] It will be noted that Adware has all the features of Payware, but does not require 

payment from the user. What Adware does require is that the user display and view ads, 
which the user will download from the software provider's site and/or one or more sites 
designated by the software provider. It will also be noted that the initial state of the 
software is Adware. 

[0060] In an exemplary preferred embodiment, each client computer downloads ads 

from the ad server 303 unobtrusively and without drawing significant bandwidth, as 
discussed in greater detail below. Moreover, the ads advantageously can be displayed in 
a manner that doesn't significantly detract from the use of the software, e.g., Eudora. 



15 



Attorney Docket No. 000370D1 



Figs. 3A and 3B illustrate advertisements integrated into the main screen of the 
exemplary Eudora e-mail software. 
[0061] Some of the terminology employed in describing the functions and novel 

features of exemplary embodiments of the present invention was presented above. 
Additional terminology which facilitates a full understanding of the present invention in 
terms of the Eudora software is presented immediately below. 



Applications 


QUALCOMM INCORPORATED has several versions of the Eudora 
software, including: 




EP4 


Eudora Pro 4.x, either Windows or Macintosh. 




Eudora 


The new three-modal version of Eudora, running in 
any of its modes. 




Payware 


Eudora running in full-feature mode, after the user 
has paid. 




Freeware 


Eudora running in reduced-feature mode. 




Adware 


Eudora running in full-feature mode with ads. 




Paid App 


Any version of Payware to which the user's 
registration entitles him/her. 




Unpaid App 


Any version of Payware newer than that to which the 
user is registered and entitled to. 


Old Eudora 


Eudora versions prior to Eudora Pro 4.x. 


User States 


A user state is the most basic concept to understanding how the 
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various modes of the application are interrelated. The user state 
determines how the program treats the user. The states are defined as 
follows: 




EP4 User 


A user of EP4 who has not registered via the old 
(non-Adware) registration process. 




Registered 
EP4 User 


A registered user of EP4. 




New User 


A user using Eudora for the first time, but who has 
not obtained a boxed copy, e.g., bundled with a 
newly purchased computer system, etc. 




Payware 
User 


A user who has paid for Eudora, entered his/her 
registration code, and is using a version of Eudora to 
which he/she is entitled. 




Box User 


This is a user who has been given their RegCode by 
an installer, either from the box product or from an 
EP4 updater, and whose registration information is 
therefore unknown. 




Free User 


A user who has chosen to use Freeware but who has 
not entered a Freeware registration code. 




Adware 
User 


A user who is using the Adware version that displays 
ads. 




Registered 

Freeware 

User 


A Freeware ("Free") user who has entered a Freeware 
registration code. 
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Registered 

Adware 

User 


An Adware user who has entered an Ad registration 
code. 




Deadbeat 
User 


A former Adware user who has been shut off due to 
Eudora's failure to receive ads (or less than a 
prescribed minimum number of ads). 


Windows and 
Dialogs 


Several windows and dialogs are used in the process. A fuller 
description of these will be given later, but the major ones are briefly 
described immediately below: 




Intro Dialog 


A dialog presented to new users explaining the 
software options to new users. 




Registration 
Nag 


A window presented to tne user every so otten to 
suggest that the user register his/her software. 




Full- 
Feature Nag 


A window presented to Freeware users requesting 
them to try Eudora Pro again. 




Free 

Downgrade 


A dialog that tells the user the features that will no 
longer be available to him/her if they switch to 
Freeware, but allows them to do so if they really 
wish. 




Code Entry 
Dialog 


A dialog allowing the user to enter their registration 
code. 




Ad Window 


A window or portion of a screen displaying an ad. 
See Figs.3A and 3B. 
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Link 

History 

Window 


A window that will display links the user has clicked 
on, i.e., ads the user has seen. 


Web Pages 


The software provider advantageously can elect to restrict 
interactions between the user and the software provider to the 
Internet to the maximum extent possible. This will allow the 
software provider the most flexibility in how the software provider 
deals with actual users. One potential list of the major pages is 
provided immediately below, although these "pages" advantageously 
may be groups of pages, or pages customized to match the 
demographics of a given user, e.g., a customized and/or branded 
version of Eudora provided by a major retailer, e.g., a private label 
version of Eudora provided to its users by an ISP. 




Freeware 
Reg Page 


A page that allows the user to register Freeware. 




Payware 
Reg Page 


A page that accepts payment for Eudora Pro and 
returns a registration code to the user. 




Adware Reg 
Page 


A page that allows users of Adware to submit their 
registration information to the software provider. 




Lost Code 
Page 


A page that helps users who have lost their 
registration codes. (May require human intervention) 




Update 
Page 


A page generated for a user that lists possible 
upgrades and the latest version for which he/she is 
registered. 
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Archived 
Versions 
r^age 


A page from which users can download all versions 
of Eudora. 




Profile Page 


A web page where users can enter their profile 
information. 


Nag 

Schedules 


A "Nag Schedule" is a bracketed set of numbers. The numbers 
signify # of days since the start of a trial period. Users will be nagged 
on the days indicated. The last number signifies what happens when 
the other numbers run out; the user will either not be nagged (0), or 
be nagged every so many days. For example, a schedule of [0,5,2] 
means the user will be nagged on the first day, the sixth day, and 
every other day thereafter. 



[0062] As mentioned above, the "software" advantageously can be provided as a single 

binary file containing the software, e.g., the Eudora software, which can be installed (if 
required) and employed by all users. This binary file will operate in one of three major 
modes of operation: Payware; Freeware; and Adware. The installation and operation 
of various functions of the software program according to the present invention will 
now be described in greater detail while referring to several state flow diagrams, which 
state diagrams illustrate the major user states and the transitions among them. In the 
flow state diagrams, the following conventions will be observed: 

[0063] Raised grey squares are conceptual names for buttons in dialogs. 

[0064] • A few paths are labeled with menu items. These items can be used to 

bring up the window in question directly, without waiting for nags. 

[0065] • In principle, any dialog or nag can be cancelled, leaving the user back in 

the initial state. 

[0066] • Web pages cannot change user state or generate more dialogs; hence, all 

web pages lead back to the user's initial state. 
[0067] With the conventions noted above, the installation of the Eudora e-mail software 

will now be described while referring to Fig. 4, which depicts state transitions when a 
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version of the software is installed by one of a new user, an old user, and an EP4 user. 
It will be noted that the software provider doesn't give the user the options to pay for 
the full feature set or to accept the software with a reduced feature set in the intro 
dialog. While the software provider will explain those options, e.g., via a dialog box 
similar to that illustrated in Fig. 4B, as well as the fact that the user can obtain these 
alternative versions of the software feature set by going through the Help menu, the 
software defaults to the Adware version. 

[0068] The path taken by EP4 users and box purchasers illustrated in Fig. 4A merits 

some elaboration. The Code Generator referred to in Fig. 4A advantageously is 
instantiated by the installer module of the binary file, not in the Eudora e-mail program 
itself. If the user is using the software's 4.x -> 4.3 update function, the software 
searches for a copy of EP4 and, on finding a copy of the software, the Code Generator 
permits the user to generate a RegCode file. If the user is running the installer out of the 
box, the installer permits RegCode generation without looking for a copy of EP4 first. It 
should be mentioned that the RegCode file so generated is special in that it contains a 
line saying "Eudora-Needs-Registration: YES." The Eudora e-mail software will notice 
this line of text, put the user into the unregistered state, and then nag the user to register 
the software. Once the user registers, the same registration code will be re-transmitted to 
the user, and the Eudora e-mail software will silently accept it (since it will be the same 
as the current code), and turn off the need to register flag in the e-mail software. 

[0069] Fig. 5A illustrates a state flow diagram of the process by which the Adware user 

becomes a registered Adware user. It will be appreciated that, in the illustrated 
exemplary case, the registration process necessitates interaction between client 
computer 100a and a registration server 301, which are connected to one another via 
network 200. In Fig. 5A, the Adware user indicated in Fig. 4A registers with the 
software provider through several alternative mechanisms. For example, the Ad user 
may wish to register, and simply activates the "HELP" pulldown menu, which is 
available from the tool bar illustrated at the top of Fig. 3A, and selects the Payment & 
Registration option, as depicted in Fig. 5B. Alternatively, the Adware user may receive 
a Nag box, i.e., a Nag dialog box, generated by the software at a predetermined time, as 
discussed more fully below. Finally, the Ad user may receive a registration via e-mail, 
i.e., a registration code generated by server 301 and transmitted to the client computer 
100a by way of e-mail server 304. 
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[0070] As shown in Fig. 5B, the Payment & Registration Window provides several 

selection buttons, which allow the Ad user to register the Adware, pay for the software, 
list all versions available to the user, customize or modify the ad stream by providing 
demographic information, enter a received registration code, and downgrade to the 
reduced feature set offered to Freeware users. See Figs. 5C - 5G. It should be 
mentioned that the user can enter a registration code to become one of a registered 
Adware user, a registered Freeware user, and a registered Payware user. See Fig. 5F. It 
will be appreciated that the software operates in accordance with the same state flow 
diagram for Registered Adware Users, except that the Registered Adware User is not 
subjected to the Registration Nag. 

[0071] The software provider advantageously can use a registration scheme with a self- 

validating registration code, so that databases do not need to be used to validate 
registrations. The algorithm for verification is intended to satisfy several conflicting 
constraints, i.e., it needs to be secure, yet easy to implement and not unduly burdensome 
for the user. The Eudora e-mail software checks its registration code at startup for 
validity. If the registration code is invalid, the user should be considered unregistered. If 
the user is a paid mode user, this will involve a switch to Sponsored mode, about which 
the user should be warned using a dialog box (not shown). This alert will be followed 
by an opportunity to reenter the code. The necessary inputs to generate the registration 
code are as follows: 



RegName 



The name the user wishes to register under. The software provider will 
imply but not require that this be the user's real name. The only thing 
this name will be used for is registration. 

Supplied by the user. When the software provider actually collects this 
name from the user, the software provider will ask for it in terms of 
first and last names, called RegFirstName and RegLastName, 
respectively. RegName is built by concatenating RegFirstName, a 
single space, and RegLastName. Each of the first and last names is 
limited to 20 significant characters; beyond that, characters will be 
ignored. 
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RegMonth 


The date of the registration, expressed as the number of months since 
Jan 1, 1999, e.g., 8 bits (20 years). All l's is reserved are for "never 
expires" situations. 


Product 


A numeric code indicating what product the registration is for. The 
user will choose the product; the software provider will translate that 
choice into an 8-bit code. 



[0072] It will be appreciated that a plurality of RegCode algorithms advantageously can 

be employed in generating a self-validating registration code. In brief, the software 
provider takes the inputs listed above, checksums them, mixes the inputs (including the 
RegName) and the checksum together in according to any one of a variety of 
algorithms, and encodes the result as a 16-bit number string. It will also be appreciated 
that the encoding and bit-mixing can be reversed and then, together with the RegName, 
the checksum can be used to verify the validity of the registration code. 

[0073] It should be noted that the software provider will store registration codes 

separately for Freeware (Eudora Light), Adware (Sponsored) and Payware (Eudora Pro) 
software modes. Acceptance of a registrations code for one mode of operation does not 
imply that the registration codes for the other modes should be destroyed. 

[0074] Once the registration code has been generated, the user must somehow enter the 

valid RegCode into the Eudora e-mail client. This can be accomplished in one of three 
ways: 

[0075] • Manually. Users can type or paste values into the Enter Code dialog box. 

See Fig. 5F. 

[0076] • Windows Registry. At Eudora startup, the software will look for the 

RegCode in the Windows registry (e.g., Software\Qualcomm\Eudora\Check, 
FName, LName, RCode). The values should be copied into the preferences 
register or associated lookup table of the e-mail client, if these preferences 
are found and valid. 

[0077] • RegCode File. At Eudora startup, the software will look for a file in the 

application software folder named "RegCode.dat," in an exemplary case. 
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The values should be copied into the preferences register or associated 
lookup table of the e-mail client, if these preferences are found and valid. 

[0078] It should also be mentioned that the software provider will allow a special-case 

MEME part to be mailed to the Eudora e-mail client. The user receiving this part will 
automatically be asked to verify and enter the information. He/she can also execute the 
attachment again later. However, he/she cannot forward the attachment to anyone else 
using the Eudora e-mail client, because a special Content-Type attribute ("regCode") is 
required to activate the part, and the Eudora e-mail client can't send those. 

[0079] The format of the MIME part (and the RegCode file) is that of a text file 

containing RFC822-header-style fields. It has a registered MIME type of 
application/vnd.eudora.data. The fields included in the part are: 



Eudora-File-Type 


This is always the first field, and describes what sort of 
information the rest of the file contains. Its value will be 
either "regFile" or "Profile." 


Eudora-First-Name 


The first (given) name of the registrant, in US-ASCII. 


Eudora-Last-Name 


The last (family) name of the registrant, in US-ASCII. 


Eudora-Reg-Code 


The registration code as produced by the registration system 


Profile 


Profile information. This takes the form of a relatively 
short, e.g., 127 bytes, ASCII string. A profile is generated 
for each user during the registration process. 


Eudora-Needs- 
Registration: 


If this field contains "YES", then the user should be nagged 
to register their copy of Eudora. This is used by installers 
that generate RegCodes that the software provider 
otherwise would not have in its database. 
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Mailed- 1 o 


This is the address the information was mailed to. If this 




field is present and does not match any of the user's 




personalities or "me" nickname, the information should not 




be acted on. 



[0080] It should be noted that the Eudora-File-Type field must be present. The other 

fields listed above may or may not be present. 
[0081] It will be appreciated from the discussion above that RegCodes mailed to the 

user should be validated prior to use. In order to be used, a RegCode should meet the 

following tests: 

[0082] • Validity - An invalid RegCode should be ignored. 

[0083] • Directness - The mailed-to field of the RegCode should contain an address for 

one of the user's personalities or be in the user's "me" nickname. 

[0084] • Applicability - A new RegCode should not automatically override an existing 

valid RegCode. The only exceptions to this policy are that a Payware mode 
RegCode should override a Freeware or Adware RegCode, and a Payware mode 
RegCode that is the same as the user's existing Payware mode RegCode can be 
used to disable the "Eudora-Needs-Regi strati on" Nag. 

[0085] Once the RegCode has been determined to meet the above tests, the user should 

be asked to accept the code. An exemplary acceptance dialog box is illustrated in Fig. 
5F. 

[0086] As mentioned above, the registration code is self-validating, since one part is a 

function of the other. However, there is another sense of "validation" to be considered, 
i.e., whether or not the registration code is "valid" for use with a particular version of 
Eudora. This is accomplished by comparing the ExpMonth in the registration code with 
a BuildMonth field the software provider will put into the application (in a place that 
cannot be overwritten by plug-ins, settings, etc.). If the ExpMonth and the BuildMonth 
correspond, the registration is deemed valid by the e-mail client. 

[0087] Fig. 6A illustrates a state flow diagram of the process by which a Freeware user 

can become a Registered Free User. It will be appreciated that the state flow diagrams 
of Figs. 5A and 6A are similar in many respects. However, the state flow diagram of 
Fig. 6A allows for an additional Nag dialog box, i.e., the so-called Feature Nag dialog 
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box pictured in Fig. 6B, to remind both the Free User and the Registered Free User of 
the enhanced features available to Adware and Payware users. With respect to 
Freeware Users and Registered Freeware Users, it will be appreciated that the 
Registered Freeware Users will not receive the Registration Nag dialog box. It will be 
appreciated that the state flow diagram illustrated in Fig. 6A is very similar to that 
applicable to the Adware Users (Fig. 5A), with the exception that Freeware Users are 
given the option to try the full features rather than enter their demographic information. 

[0088] It should also be mentioned at this point that all users will receive an Update 

Nag dialog box (not shown) at a predetermined interval. Eudora checks the Update 
Page once per week during an e-mail session. If the Update page has changed, the user 
is nagged to update the Eudora e-mail software. Even if the page hasn't changed, the 
user is nagged on a 30-day schedule to check for updates, to ensure that he/she has the 
latest software version. See the state flow diagram of Fig. 7A. The Update Nag 
presents the user with versions to which he/she is entitled to upgrade (if any). See Fig. 
7B. The Nag itself is an HTML document with links to versions of the Eudora e-mail 
software for the user to download. 

[0089] Fig. 8 illustrates an exemplary state flow diagram of the process by which a Box 

user can become a Paid user, i.e., a Payware user. It will be appreciated that the only 
Nag the software provider presents specifically to the Box users is the Registration Nag. 
Once a Box user registers, the Box user is converted into a normal Paid user. It should 
be mentioned however that the payment date for the Box user is set to a specific value 
by the software provider, so that the software provider can control what versions of the 
software the Box user will receive, e.g., the period of time for which the user will 
receive updates from the software provider for free going forward. 

[0090] Having introduced the concept of nagging, this would be a convenient point to 

discuss various features of nagging implemented in the software according to the 
present invention. Two major issue are (1) how the software provider nags the user, and 
(2) when the software provider nags the user. 

[0091] Ideally, Nag Windows are modeless windows. The user can close them using 

close boxes, or dismiss them by taking one of their action items, or simply leave them 
open and let them drift wherever they will in the window list. Due to implementation 
constraints, Windows Nag Windows will be slightly different in behavior than MacOS 
Nag Windows, which are discussed below. The Nag Windows are floating windows; the 
software provider expects that the user will probably dismiss the Nag Window in fairly 
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short order. It will be appreciated that the Nag Windows will not, however, stop 
background tasks from executing. 

[0092] It should be mentioned that there is at most one Nag Window of each variety 

open at a time; old windows of the same variety advantageously will be recycled. That 
is, if a given Nag Window is still open the next time the user is due to be nagged, that 
window will be reused and brought back to the top of the window stack. It should also 
be mentioned that all Nags applicable to the user should be available to the user by 
selection from the Help menu, so that the user who dismisses one of the Nag Windows 
inadvertently can deliberately nag him/her-self if he/she wishes, although such manual 
Nag invocations do not reset the Nag's timer. 

[0093] Preferably, Nag Windows will be opened on top of all other windows, and no 

automatically opened windows, including, for example "Tip of the Day" and other 
dialog boxes and excluding other Nag Windows, will ever be placed above them until 
the user has manually brought another, non-Nag Window above them. Due to the 
implementation constraints in the Windows version of the Eudora e-mail software, the 
only windows that can obscure Nags would be other floating windows. It will be 
appreciated that this is chiefly due to the requirement that Multiple Document Interface 
(MDI) child windows be maximizable. It should be mentioned that is a standard 
Windows interface used by many popular Windows applications and utilities, such as 
the Windows Program Manager, and the Windows File Manager; the MDI interface is 
also part of the Common User Access (CUA) standard set by IBM. Each MDI- 
compliant application enables you to open child windows for file-specific tasks such as 
editing text, managing a database, or working with a spreadsheet, to name but a few of 
the possible tasks. 

[0094] Fig. 10 illustrates a flow chart for Nag Window display in MacOS versions of 

the Eudora e-mail software according to an exemplary embodiment of the present 
invention. In Fig. 10, the software presents just the In mailbox, as denoted by the 
symbol (1), i.e., time (1). The Eudora e-mail software then determines that it needs to 
nag the user, and places the Nag atop the mailbox, as denoted by the symbol (2). Some 
mail arrives in the "Fresh Meat" mailbox. Ordinarily, this would open on top. However, 
since there is a "new" Nag being displayed by the software, i.e., one the user has not 
manually sent behind anything, the "Fresh Meat" instead opens below the Nag, as 
denoted by symbol (3). The user manually brings Fresh Meat to the front, as denoted by 
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symbol (4). After that, when mail arrives in More Meat, the Nag is no longer new, and 
More Meat can be opened on top in the normal manner, as denoted by the symbol (5). 

[0095] The placement of Nag Windows in any of the Windows environments is, in 

general, considerably simpler. Nag Windows simply float outside the MDI box, above 
other floating windows, until the user closes them. The exception to this rule is the 
Update Nag, which acts like a MacOS Nag Window, if the user assumes that the entire 
Macintosh diagram takes place inside an MDI box. Note particularly that this indicates 
that the Update Nag may be maximized in the Windows environment. 

[00961 Although the basic concept of Nag Schedules was introduced above, a more 

detailed discussion of Nag Schedules at this point would facilitate the understanding of 
certain aspects and features of the software according to an exemplary preferred 
embodiment of the present invention. In the Eudora e-mail software, each schedule is a 
set of numbers representing (save for the last) the number of days since a given date (the 
Nag base). The software provider further must keep track of the last time the user was 
nagged (the last lag). Note that both the Nag base and last Nag should be tracked 
separately for each type of Nag; the software provider must not mix values for 
Registration Nags and Update Nags, for example. The last number of the Nag Schedule 
is a repeat interval. Once the other Nags are all exhausted, the user is nagged each time 
this last number of days passes. 

[0097] The best way to understand a Nag Schedule is to view the schedule as a timeline, 

as illustrated in Fig. 11. This particular timeline is for a Nag Schedule of [0,4,9,12,3]. 
Note that the Nags which will occur at the 15 and 18 day points are there because of the 
final number, the repeat interval (of 3 days). Thus, in Fig. 11, the user is due to be 
nagged if there is a Nag day greater than the last Nag and less than or equal to the 
current day. If more than one Nag day has passed, the user is still nagged only once. 

[0098] It should be mentioned that once the Nag Window has been opened, the last Nag 

is reset to the current day. It should also be mentioned that a final Nag interval of 0 
indicates that the Nag is not done any more after the defined period has expired. It will 
be appreciated that the Eudora e-mail software advantageously includes a software 
subroutine which determines whether any Nags are due at application startup and at the 
completion of each mail check. With respect to the latter case, the software checks the 
modification date on the Update Page once per week during a mail check. If the Update 
Page has been modified during the past week, the software provider will download 
update information during the mail check, and nag the user to update his/her software, 
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e.g., the Eudora e-mail software. See Fig. 7B. Finally, it will be noted that when a 
user's state changes so that an open Nag is no longer relevant, that Nag is closed and no 
longer displayed. 

[0099] The preceding discussion also touched briefly on various issues with respect to 

ads; these issues will be developed more fully immediately below. More specifically, 
the major client issues involving ads are how the software displays the ads, when the 
software displays the ads, how the software obtains the ads, how the software provider 
obtains and transmits demographic information, and how the software provider verifies 
that ads are actually being displayed. 

[0100] Referring again to Fig. 3 A, the main window of the Eudora e-mail software 

shows a squarish ad and three ad buttons in opposite corners of the main window. It 
should be mentioned that this particular squarish ad is 144 pixels high by 128 pixels 
wide; the software will accommodate ads as large as 144 pixels by 144 pixels. It will be 
appreciated that the area of the window usable by the mailboxes has been reduced 
approximately 38%; however, it will also be appreciated that the content area has been 
left untouched. Fig. 3B illustrates an alternative main window where a small graphic or 
placard is employed, e.g., in the lower right corner, to indicate that the main window is 
sponsored. 

[0101] It will be appreciated that the actual information that the software provider can 

accept from advertisers will be relatively simple. For standard ads, such as that depicted 
in the lower left-hand corner of Fig. 3A, the ad will consist of an image file, e.g., a GIF 
file, a PNG file, a JPEG file, etc., of not more than 15K, and not more thanl44 pixels 
tall by 144 pixels wide. Preferably, this image file will employ the Web Safe Color 
Palette. This palette, which is sometimes to as the Browser-Safe Palette, contains only 
216 colors out of a possible 256 colors definable by 8-bits. The remaining 40 colors 
vary on Macs and PCs. By eliminating the 40 variable colors, this palette is optimized 
for cross-platform use. Moreover, the image file advantageously will be associated with 
a single uniform resource name (URN) to which users who click on the ad will be 
directed. Each advertiser will also specify the desired scheduling information for the ad, 
as discussed in greater detail below. In order to facilitate the transmission of the ad to 
the software provider, e.g., QUALCOMM INCORPORATED, the advertiser may wrap 
the ad in HTML. The software provider advantageously can also employ HTML- 
wrapped ads, since this will allow the software provider to include ad parameters as 
META tags in the HTML page, specify the link address, etc. 



29 



Attorney Docket No. 000370D1 



[0102] Moreover, the Toolbar icons will be requested in GIF format as well, but will 

actually be delivered to the client in a composite format and transformed into standard 
icons. In addition, placards for sponsors of the Freeware version illustrated in Fig. 3B 
should be no more than 31 pixels tall, and on the order of 88 pixels wide, though the 
precise width can be varied at runtime. 

[0103] It should be mentioned here that when the user clicks on an ad, the software 

provider will normally take the user to the software provider's click-through counter 
and then redirect the user's browser to the link listed with the ad. The click-through 
counter advantageously can be one of the software provider's servers, e.g., one of 
servers 302 and 303. It will be appreciated that this will require that the software 
provider will compose a URN which includes a server name, some tracking 
information, and the ultimate destination URN, and then the server will redirect the 
user's browser to the destination URN. 

[0104] . One complication occurs if the user is offline at the time that the click-through is 

attempted. When the user is offline, several possible actions by the software are 
possible. For example, the software could initiate an online session. Alternatively, the 
software could simply flag the link using the link history facility. See Fig. 12, which 
depicts a window/menu that the software maintains, similar to the history lists 
maintained by most browsers. When the ad is clicked while the software is offline, the 
software advantageously adds the link to the link history window, and flags this link so 
that the user knows he/she had wanted, but was unable, to visit that site during a 
previous e-mail session. 

[0105] Moreover, the software advantageously may be constructed to permit the user's 

browser respond to the click-through. It will be appreciated that some browsers have 
sophisticated features of their own for dealing with offline conditions, and the software 
provider shouldn't discount the idea that the user might wish to rely on them. 
Alternatively, the software may permit transmission of the link to the browser for 
subsequent handling by the browser when it is online, i.e., the software can allow the 
user to tell the software provider to send the link to the user's browser the next time 
he/she is online. 

[0106] In summary, the software provider will, in an exemplary and non-limiting case, 

mandate that the following standard for all advertisements submitted by advertisers: 

[0107] • No larger than 144x144 pixels. Ads smaller than this will be centered in 

a 144x144 window and surrounded by the standard frame color. 
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[0108] • GIF or JPEG. The software provider advantageously can convert the 

GIF file to a PhotoShop (PNG) file, but this is transparent. It should be noted that the 
software provider will not presently accept PNG ads directly, because of the gamma 
bugs in PhotoShop. 

[0109] • No larger than 15K. This will reduce the bandwidth required to transmit 

the ad as well as the goodwill cost of user bandwidth. 
[0110] • No animation. This is a cornerstone of the "unobtrusive" message to 

users aspect of exemplary embodiments of the present invention. 
[0111] • A single URN of not more than 900 characters. There are suspected 

limits of IK on URN size. Limiting the customer's URN to 900 characters will allow 

the software provider to annotate the URN and still stay within the IK limit. 
[0112] • A user-friendly title string of not more than 31 characters. This string 

will be displayed in the link history window, and should be something users will relate 

to. 

[0113] • Use Web Safe Color Palette. This 216-color palette optimized for users 

with 256-color systems, as mentioned above. 

[0114] It should be mentioned that Toolbar buttons, i.e., the buttons in the upper right- 

hand corner of Fig. 3A have the same requirement as standard ads, except for the 
following: 

[0115] • Both 16x16 and 32x32 sizes required. These are the sizes the client 

supports, the software provider needs them both. 
[01 16] • GIF only. The software will not render JPEG images in the toolbar. 

[0117] With respect to the co-brand spot ad illustrated in the lower right-hand corner of 

Fig. 3B, the spot has the same requirement as standard ads, except for the following: 
[0118] • No larger than 95 pixels wide by 31 pixels high. 

[0119] • GIF only. 

[0120] One troublesome issue regarding the ad placement illustrated in Fig. 3A is the 

relative ease with which a user might be able to hide the ads from view by placing a 
small window directly over the ad. Advantageously, the software performs a check to 
determine that the ad is both onscreen and uncovered. If the screen state does not satisfy 
both of these criteria, the software will either nag the user to uncover the ad or 
automatically re-order the windows so that the ad is uncovered. If the user persists in 
covering the ad for a predetermined period of time, the software will automatically 
devolve to freeware mode. 
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[0121] Since one of the major reasons for providing an Adware version of software 

such as the Eudora e-mail program is to provide a mechanism by which advertisers can 
subsidize the cost of the software, the software provider is clearly motivated to ensure 
that all Eudora users are actually looking at the ads. Stated another way, displaying an 
ad on the screen of the client computer 100a, for example, while the user is in another 
room does not justify the expense of the ad for the advertiser. For that reason, the 
software includes functions which permit measurement of the actual time that the user is 
in front of the computer while the ad is present. 

[0122] Absent some sort of positive ocular fastening device, the best thing the software 

can do to measure user attention is to monitor for user input to the client computer 100a, 
thus verifying the user's presence in front of the display device 208. Given that the 
primary user input devices to the client computer 100a are the mouse 204 and the 
keyboard 203, the e-mail client will monitor for both mouse and keyboard operation by 
the user when the Adware version of the Eudora e-mail client is frontmost, and 
periodically report this activity back to, for example, the software provider. In other 
words, the user will be considered "present and accounted for" if the mouse moves 
significantly, if a mouse button states change, or if keys are pressed or released. 
Moreover, the software will consider a period before and after such an event as "face 
time" for the ad. In an exemplary case of the software according to the present 
invention, the software measures the period and refers to the total length of this period 
as kFacelntervaL There is no need to be overly precise about this value, e.g., a 
kFacelnterval of sixty (60 )seconds, which begins with a user event, is employed in the 
exemplary, non-limiting case being discussed. 

[0123] Having discussed the format of the ads being displayed by the software, a 

detailed discussion of the methodology by which the ads are actually obtained for 
display will now be presented. The general methodology for obtaining ads for display 
is to connect to a QUALCOMM INCORPORATED site during a mail check, or some 
other time when the software senses a live network connection, and download ads into a 
local cache. It will be appreciated that the act of downloading the ad can be the trigger 
for billing the advertiser, in order to avoid the necessity of collecting billing information 
from individual clients. In contrast, proprietary systems such as that provided by JUNO, 
upload ad display data to the designated e-mail server whenever the user accesses 
his/her e-mail account for any reason. 
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[0124] In order to make reasonable decisions about how to download ads, the software 

provider needs to have some idea of what impact the ad downloads will have on users. 
In order to assess that impact, the software provider must make assumptions (or gather 
information) about what a typical Eudora user's habits are, and what the ads will be like 
in terms of transmission characteristics. Part of the Adware process is to add 
instrumentation in the software client so that the software provider can begin to answer 
these questions intelligently, rather than by guesswork. However, one must start with 
some basic assumptions. For example, Fig. 13A is a table listing the assumptions used 
in determining the impact of ad transmission on e-mail program operations; Fig. 13B is 
a table listing the bandwidth requirements in terms of the subscriber base versus of the 
number of new ads to be downloaded each day to the subscribers. The implications of 
these calculations are as follows. Given that the goal is for an average turnover of an ad 
is, for example, three days, the top line in the table illustrated in Fig. 13B would be the 
one used by the software provider. The worst-case, i.e., maximum bandwidth, scenario 
would be to turn over, for example, 25 ads a day. These values are highlighted in the 
table of Fig. 13B. 

[0125] In order to determine what ads are to be shown for a particular user class, as well 

as in order to transmit particular ad parameters, the software provider advantageously 
employs a PlayList. The PlayList is in its essence a list of URNs from which to fetch the 
actual ads as well as a set of attribute-value pairs, on a per-ad basis. The exact format of 
the PlayList is discussed in greater detail shortly. PlayLists will specify the complete set 
of ads the client should have, along with parameters for displaying those ads, as 
discussed immediately below. It should be noted that ads may appear in a PlayList but 
not be scheduled for display for a long time (or even at all). The presence of such ads in 
the PlayList will cause the client to retrieve the ads for storage on the client for future 
display. The general requirements for the PlayList are as follows: 

[0126] 1) The request for a PlayList will contain information to help the PlayList 

server determine what ads a copy of Eudora is required to fetch. 

[0127] 2) The PlayList can also contain parameters for Eudora as a whole, 

including the ability to modify how often New PlayLists are checked for. 

[0128] 3) PlayLists are allowed to specify whether or not they should replace all 

older PlayLists or merely be merged with them. It should be mentioned that the merge 
function will allow a more web-like advertising model, e.g., a model employing a 
rotating ad pool, should the software provider choose to employ such a model. 

33 



Attorney Docket No. 000370D1 



[0129] The basic ad fetch process will now be described while referring to Fig. 14, 

which is a state flow diagram of an exemplary ad fetch process according to the present 
invention, and Fig. 1. First, the client software running on client computer 100a 
identifies itself to the PlayList server 302, e.g., ads.eudora.com. The client software, 
e.g., the Eudora software, provides to the PlayList server 302 basic client information 
and the ED of the PlayList the client software currently has installed. The 
ads.eudora.com server responds with either an indication that the current PlayList is still 
valid, uses an Hyper Text Transfer Protocol (HTTP) redirect to send the client to a 
different PlayList server, e.g., another PlayList server 302', or responds directly with the 
New PlayList from PlayList server 302. See Fig. 14. In the event that the New PlayList 
is received from PlayList server 302, the client software compares the New PlayList 
with its current set of ads, and begins fetching ads not resident in the e-mail client's ad 
cache from one of more ad servers, e.g., the ad server 303 illustrated in Fig. 1, according 
to URNs included in the PlayList. The client software also deletes ads not currently 
appearing in the PlayList. 

[0130] Advantageously, the client software performs a check for a New PlayList every 

three days. It should be mentioned that the 3 day interval between PlayList checks is 
arbitrary and applicable only to the exemplary preferred embodiments of the present 
invention being discussed. It should also be mentioned that the ads preferably will be 
fetched as needed to fill the PlayList, possibly over many mail checks. Moreover, the ad 
fetch process will be limited to one minute per mail check, irrespective of the tasking of 
either the e-mail client software or the client computer 100a. After one minute, the 
client software will disconnect from the ad server 303. This will often mean that the e- 
mail client software has not filled the PlayList when the ad fetch operation is 
terminated. This is acceptable. The software will utilize the available ads while the 
remaining ads are being downloaded. 

[0131] Furthermore, the software provider advantageously can provide for multiple 

servers on a peer with ads.eudora.com server 303. It will be appreciated that these 
servers will provide extra ads for some Eudora user communities, e.g., all of the users at 
a company serviced by one ISP, etc. Stated another way, an ISP which provides 
additional services such as local and long distance telephone access may wish to cross 
promote these services to its own customer base. Thus, the ISP advantageously can 
contract for such localized promotion. The PlayLists transmitted to the ISP's branded 
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Adware e-mail clients would be linked to an ad server 303" maintained by the ISP in 
that instance. 

[0132] Given a set of available ads, the software still needs to choose which ad to 

display next. It will be appreciated that this is a matter of much excitement in the Web 
ad industry, where many choices are allegedly made to maximize the profit of the 
advertiser. In particular, ads that generate better user response are preferred because 
such ads generate extra revenue - such ads are frequently tied to the content of the Web 
page upon which they are displayed. However, it is unlikely that either the software 
provider or the client software will be able to derive a significant benefit from the ad 
scheduling algorithms currently run on ad services. This is in part due to the fact that the 
ads being displayed by the e-mail client software are divorced from the content being 
displayed, i.e., neither the software provider nor the client software are cognizant of the 
content of any particular ad that the user is looking at, and in part due to the fact that the 
e-mail client software will be requesting ads in a batch for later display, rather than 
requesting them in "real time". 

[0133] As mentioned above, the PlayLists provide certain global inputs to the ad 

scheduling algorithm, including the parameters listed in the table immediately 
following. 



PARAMETER 


DESCRIPTION 


FaceTimeQuota 


The amount of time per day that the e-mail client software is 
supposed to show the ad. 


Rerunlnterval 


The age beyond which ads should not be "rerun" after the 
"runout", i.e., maximum permissible, time is passed. 



[0134] In addition, the per-ad inputs in the PlayList associated with ad scheduling are 

set forth in the following table. 
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PARAMETER 


DESCRIPTION 


ShowFor 


This is the number of seconds the ad should be shown for at any 
given time. This number might be small, like a TV ad (e.g., 30), 
or large, more like a billboard (e.g., 3600 for one hour, 
uninterrupted). 


ShowForMax 


Maximum total amount of time to show this ad. The ad is 
exhausted after this time, and should be discarded once new ads 
arrive. 


DayMax 


Maximum number of times per day to show this particular ad. 


BlackBefore 


The amount of time the ad window should be blank before the 
ad is displayed. 


BlackAfter 


The amount of time the ad window should be blank after the ad 
is displayed. BlackAfter runs concurrently with the blackBefore 
of the next ad, so that the actual time between ads is 
max(blackAfter, blackBefore), not blackAfter + blackBefore. 


StartDT 


Date/time (time zone optional) before which the ad should not 
run. 


EndDT 


Date/time (time zone optional) after which the ad should not 
run. 



[0135] There are some values the software provider computes that are also input to the 

scheduling algorithm. These global values are listed in the table which follows. 
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pad A1VTFTFH 


DFSCRTPTTON 


AdFaceTimeTod 


The total amount of ad Face time for the current day during 

whir*h rpoiilar aH<* havp hppn ^hown 


TotalFaceTimeT 
oday 


The total amount of Face time for the current day. 



[0136] The software also keeps track of and reports these values to the software 

provider for every ad: 



PARAMETER 


DESCRIPTION 


NumberShownToday 


The number of times an ad has been shown on the current 
day. 


ThisShowTime 


The amount of face time the current ad has received. 


LastShownDate 


The last date/time that the e-mail client software showed 
this ad. 



[0137] Advantageously, the software provider implements three major states of the ad 

scheduler, the regularState, the runoutState, and the rerunState. In the regularState, the 
e-mail client software advantageously is showing regular ads and accounting for them. 
It will be appreciated that this is what actually generates charges for the bulk of the ads 
displayed on the e-mail client. In contrast, the runoutState is selected when the e-mail 
client software has shown enough regular ads to fill the assigned faceTimeQuota, and 
the ad cache includes one or more runout ads available for showing. In the rerunState, 
the e-mail client software has exhausted both its regular ad quota and the runout ads, 
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i.e., the e-mail client software is now reshowing the regular ads, but the software 
provider is not charging for them. 

[0138] It should be mentioned here that the software provider advantageously can 

provide a custom installer to various ISPs, book publishers, etc., that will label or brand 
the copies of Eudora that they have distributed. The software provider will then credit 
these distributors with a percentage of the ad revenue generated by the clients they 
distribute. It will be appreciated that these credits may be offset by cross promotional 
activities associated with each branded version of the Adware e-mail client, for the 
reasons previously discussed. 

[0139] Given the discussion presented immediately above, a more detailed explanation 

of various aspects of the exemplary e-mail client software according to the present 
invention can now be provided. 

[0140] As previously noted, the PlayList is a way to control the fetching and display of 

ads in software, e.g., in the Eudora e-mail client. The primary benefits associated with 
the PlayList are the separation of ad parameters from ad images, insulation of the 
Eudora client from intimate knowledge of ad image servers, and centralized server 
intelligence in ad distribution, without requiring user registration or centralized user 
databases. Thus, it will be appreciated that PlayLists are extremely malleable objects. 
In an exemplary case, the PlayLists can exert varying degrees of control over how the 
Eudora client behaves, from specifying the exact set of ads Eudora runs to simply 
transmitting abstract URNs which will choose their own ads. If PlayLists are used to 
their fullest advantage, they will give the software provider a powerful tool in 
controlling ad display in software such as Eudora; if PlayLists are later deemed 
irrelevant, the PlayLists cost the software provider one extra, brief network connection 
per day. 

[0141] As discussed above with respect to Figs. 1 and 14, the client computer 100a 

connects to a PlayList server 302 (which may redirect to a different server 302') via a 
network 200. Then, the PlayList server 302 returns a PlayList to the client computer 
100a via the network 200. Subsequently, the e-mail client software on the client 
computer fetches the ads specified in the PlayList. 

[0142] The PlayList Request, which is sent by the Eudora client to the PlayList server 

302 in order to initiate the ad fetch process, is not a simple burst of binary code. The 
PlayList Request is a block of extensible markup language (XML) code employed to 
provide the server 302 with sufficient information to build or select the proper New 
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PlayList for the user. The information in the PlayList Request is shown in the following 
table. 



PARAMETER 


DESCRIPTION 


User Agent 


This is a string identifying the application requesting the PlayList, 
its version number, and the platform on which it is running. 


PlayList(s) 


This identifies the PlayList(s) that the client is currently using. This 
may have multiple values if the client is working off more than one 
PlayList. 


Entry 


A list of the id's of the ads recently shown by this client. The 
entries are nested inside the PlayList to which they belong. 

Each entry can have zero or more of the following associated 
attributes or types (the number following the equal sign (=) 
indicates an exemplary value attached to the attribute which is used 
to achieve the description of the entry attributes provided below): 




Active="0" 


The ad is no longer being shown. 




IsRunout="l" 


The ad is a runout ad. This saves the server 
having to do a lookup on the ad. 




IsSponsor="l" 


The ad is a sponsorship ad, to be shown in 
place of the QUALCOMM logo. See Fig. 3B. 




IsButton="l 


The ad is a toolbar button. 




Ddeted="l"" 


The ad has been hidden by the user. This is 
allowed only for toolbar ads. 
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FaceTime 


This lists the amount of face time the user has 
used in the last seven calendar days. This 
allows the server to determine how many ads 
the client is likely to be able to display. The 
value for the current day is the greater of 
today's value (see faceTimeUsedToday) and 
last week's value for today. 




FaceTimeLeft 


This is a total of the amount of face time 
requested by the ads still left in the client's ad 
cache. 




FaceTimeUsedTo 
day 


This is the amount of face time the client has 
used toward displaying ads today. It can be 
used by the server to determine whether a 
date-critical ad can be shown today. 




DistributorlD 


This id is used for the bounty system, so that 
the PlayList Server can identify and credit, 
commission or otherwise reward the ISP or 
other organization that distributed this copy 
of Eudora. 




Pastry 


This is a cookie the PlayList Server gave to 
the Eudora e-mail client in the past. It could 
contain any state information/settings the 
server wishes to save. 




Profile 




Profiling information originally entered on the 
software provider's web page and 
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subsequently/concurrently stored with the e- 
mail client. 




Screen.height 


The height of the display on which the ads are 
shown, in pixels. 




Screen.width 


The width of the display on which the ads are 
shown, in pixels. 




Screen.depth 


The color depth of the display on which the 
ads are shown, in colors/bits per pixel. 




PlayListVersion 


The version # of the PlayList routine 
employed by this particular client. 



[0143] It will be appreciated that not all of these parameters are likely to be actively 

used at the same time; some are present to support particular modes of operation (see 
below), and will not be used in other modes. It should be mentioned here that every 
PlayList Request is checksummed with MD5. See RFC 1321 - 'The MD5 Message- 
Digest Algorithm" at http://www.facs.org/rfcs/rfcl321.html. The PlayList server 302 
preferably ignores requests that fail checksum verification. 

[0144] After the client makes a PlayList Request, the server 302 replies with a PlayList 

Response. Preferably, the PlayList Response is divided into two major sections; the 
Clientlnfo section, which updates general client behavior regarding ads, i.e., speed with 
which the ads turn over, and the New PlayList itself, which describes the ads the client 
should fetch. It should be mentioned that the PlayList Server, e.g., server 302, may also 
return an empty response, meaning that the e-mail client should continue on its course 
with the ads it already has. It should also be mentioned that every PlayList Response is 
checksummed with MD5, just as the PlayList Request is. The MD5 digest is encoded in 
hexadecimal and put in a "Checksum" header in the PlayList Response. 
Advantageously, the e-mail clients ignore PlayLists that fail checksum verification. 

[0145] Before describing the sections of the PlayList Response, it should be mentioned 

that the e-mail client sometimes becomes, for lack of a better term, befuddled due to old 
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client bugs, server bugs, etc. Sometimes the bad data inherited by even an updated client 
is too garbled for the system to function properly. While the client could be 
programmed to detect this condition, it is preferable to leave the task, i.e., error 
detection, to the server, which can be changed more easily. Thus, when the server 
detects that a client is "befuddled," the PlayList server 302 responds with just a single 
command: reset. No Clientlnfo should follow, no PlayList should follow, just the reset 
command. On receiving the reset command, the client discards its accumulated ad 
databases and records, including PlayLists, faceTime history, ad history, ad caches, etc. 
Everything is reset to the pristine condition that the e-mail client software had before the 
Adware software was run for the very first time. It should be mentioned that Link 
History is exempted from the reset command, both for reasons of practicality and 
because it is so user- visible. The only other item of ad data that reset does not affect is 
the ad failure counter, which should be retained across a reset. The client should then 
recognize that it has no PlayList, and make another request to the PlayList Server for the 
needed PlayList. 

[0146] The Clientlnfo section updates various client parameters. The parameters are 

listed immediately below. 



PARAMETER 


DESCRIPTION 


Reqlnterval 


This is the number of hours the client should wait before 
checking for a New PlayList. If ad turnover is high, this will be 
a small number. A sponsored freeware version might have a 
much higher number here, so that it checked for a New PlayList 
only once a week or once a month. Clients may also check for 
New PlayLists if they have ads with nonzero showForMax 
values, and the ads have used up much of their time. 


Histlnterval 


This value is the number of days the client must remember that 
it showed a particular ad. It will report this to the PlayList server 
so that the server can, at its discretion, choose not to direct the 
showing of ads for competing services to that particular client, 
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competing ads are separated from one another by the 
Histlnterval value. 


Pastry 


The previously mentioned cookie. The server can store whatever 
state information it wishes in this cookie. 


Flush 


More command than parameter, if present, it causes the client to 
discard an old PlayList or ad. Flushed ads and PlayLists are 
removed completely, and no longer show up in ad histories. 


Width 


The width in pixels the client should make the ad window be. 


Height 


The height in pixels of same. 


FacetimeQuota 


The number of seconds of facetime the client should devote to 
regular ads, before moving to the runout ad. 


Rerunlnterval 


The number of days an ad may be "rerun"; that is, shown for 
free after all other ads and the runout are exhausted. The time is 
measured from the last non-rerun showing of the ad. 



[0147] From the discussion above, it will be appreciated that the Clientlnfo section is a 

powerful feature of PlayLists. It allows the software provider to control the application 
in a global way, including segueing smoothly from one ad model to another. It will be 
appreciated that if this were the only benefit the software provider derived from 
PlayLists, it alone would make implementation of PlayLists worthwhile. 

[0148] As mentioned above, the PlayList Response is divided into two major sections; 

the Clientlnfo section, which updates general client behaviors, and the New PlayList 
itself, which describes the ads the client should fetch. The New PlayList itself has one 
global value, PlayListlD. This id is the id value that the client returns to the PlayList 
server the next time the client computer 100a connects to the PlayList server 302. It 
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will be appreciated that this PlayListED advantageously can be included in the PlayList 
Request, or can be separately uploaded to the PlayList server in a myriad of forms, e.g., 
as a cookie. The remainder of the PlayList is a list of ads. Each ad is allowed to have 
many parameters, although it's likely not all of them will be used with any single ad, 
and it is possible that some of them will never be used at all. The parameters include 
the scheduling parameters, which are described in detail above, and ad information, 
which includes the information listed immediately below. 



PARAMETER 


DESCRIPTION 


AdID 


A unique identifier for the ad in question. A 64-bit integer, the 
top 32 bits of which are a server authority id, the bottom 32 
bits of which are an identifier unique to the server authority. 


Title 


A human-friendly string used to refer to the ad. 


Src 


A URN indicating where to get the actual ad to show. This 
might be highly specific (e.g., 
http://media48.doubleclick.net/eudora/coke/drinkcoke.gif) or 
it might be much more general 

(e.g., http://ads.doubleclick.net/eudora/ad;ord=l 36784421 ?). 
Another important PlayList feature is that the PlayList permits 
the client software to pull ads from many different servers. 
The software provider could, for example, run its own servers 
in parallel with those belonging to DoubleClick, and take ads 
from each server, or some of the servers, based on the 
PlayList. 

There can be a checksum attribute on the src tag. If present, 
its value is a hexadecimal-encoded MD5 digest of the ad data. 
The client may check this checksum against the ad data. 
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IsButton 


Is this "ad" a toolbar button? If so, it will be scheduled 
separately from the main ads. The only scheduling parameters 

that are meaningful for toolbar buttons are startDT and 
endDT. 


IsSponsor 


Is this "ad" a sponsor placard? If so, it will be scheduled 
separately from the main ads. 


IsRunout 


Is this ad intended to be run after all other ads have exhausted 
their runs for a given day? There will only be one active 
isRunout ad in any client's collection of PlayLists. 


URN 


The Uniform Resource Name of the server (e.g., a Web site 
address) to which the user is directed when he/she clicks on 
the ad. 



[0149] It should be mentioned that the term Uniform Resource Name (URN) indicates a 

generic set of all names/addresses that are short strings that refer to resources available 
via the Internet. Thus, URN encompasses both a Uniform Resource Locator (URL), 
which is subset of URN schemes that have explicit instructions on how to access a 
particular resource on the Internet, and a Uniform Resource Identifier (URI), which is 
another subset of URNs. It will be appreciated that the URL and URI subsets may 
overlap. It will also be appreciated that the terms URN, URL, and URI advantageously 
can be used interchangably; whichever term is used is meant to address the named 
resource in its broadest possible sense. 

[0150] It has been mentioned in passing that not all parameters are likely to be used at 

one time. In fact, PlayLists are flexible enough to support many ad models. PlayLists 
are crucial to some ad models, to others they are helpful but not central, to still others 
they are marginally useful, but do not present significant impediments. The use of 
PlayLists does not predispose the software provider towards any specific ad model; the 
PlayLists advantageously can be used to support any ad models that the software 
provider chooses. Indeed, PlayLists permit the software provider to switch between ad 
models midstream, should the software provider decide to do so. In the discussion that 

45 



Attorney Docket No. 000370D1 



follows, several ad models will be discussed with respect to Figs. 16A and 16B in an 
effort to illustrate how PlayLists would be used for each ad model. It will be appreciated 
that this will demonstrate the essential neutrality of the PlayList concept to the ad 
model. 

[0151] Fig. 16A illustrates the ad model associated with persistent ads while Fig. 16B 

depicts the parameters associated with a short-lived ad model. One thing to notice here 
is how few of the parameters from any of the sections appear in the chart. It will be 
appreciated that varying as few as five parameters advantageously causes the Adware to 
shift between these two distinct ad modes. That's because they are largely not relevant 
to the choice of ad model. The parameters will either be used or not, irrespective of the 
ad model. For example, the software provider can implement blank space after an ad in 
any model, and the software provider can eschew blank space after an ad in any model. 
Most of the parameters fall into this it-just-doesn't-matter category. 

[0152] With respect to the short-lived ad model, it will be appreciated that the software 

provider accepts many ads; either from many advertisers or only a few advertisers. Ads 
do not persist for many days; they're used up and discarded at a relatively rapid rate. In 
this model, PlayLists will be used additively. Each time the client runs low on ads, it 
will ask for another PlayList which will describe a few more ads to mix with the clients' 
existing ads. When ads exceed their allotted time, the ads are discarded. In this ad 
model, the PlayList server really only serves to transmit parameters for ads. However, 
that is acceptable, since the parameters have to be transmitted somehow, after all. 

[0153] Suppose the software provider wants to mix ad models, e.g., desires to provide a 

mix of long-running ads and short-lived ads. How this situation is handled depends on 
the stoichiometry. If the cache is or will be filled with mostly persistent ads and only a 
few short-lived ones, the software provider can merely increase the reqlnterval and use 
PlayLists as in the Persistent Ad Model. In other words, the software provider merely 
picks a few random ads to go on each PlayList, and picks a few more random ads to go 
on the next PlayList, which the client will fetch the next day. If, on the other hand, the 
cache will contain mostly short-lived ads and only a few persistent ads, the computer 
system 10 will use multiple PlayLists. One PlayList will list the persistent ads, as 
discussed above; the remaining facetime will be filled using PlayLists of short-lived 
ads. 
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[0154] The above discussion illustrates how PlayLists can be used to support widely 

differing ad models. The reason PlayLists can do this is that they're really only an extra 
level of server control and in between Eudora and its ads. 

[0155] Given the importance of ads to Adware e-mail software, one of the software 

provider's key concerns is "what happens if the Adware does not receive ads?" For 
example, users or ISPs may simply shut off the flow of ads to Eudora by using firewalls 
or other means. Alternatively, the user may simply delete ads or Playlists (or both) 
from, for example, his/her computer on a random or periodic basis. If this happens, then 
users wil have no ads to display, i.e., the users get the full-featured version of Eudora 
without either seeing ads or paying. This would defeat one significant aspect of the 
exemplary software according to the present invention. On the other hand, users may 
have hardware or software problems or other issues that keep them from fetching ads, or 
the software provider's ad servers might even be down for some reason. Users should 
not be punished for this. 

[0156] The software provider will distinguish between these two situations by asking a 

simple question, i.e., is the user sending or receiving mail? If the answer is yes, the 
software provider will assume that the blocking of ads is something the software 
provider needs to address. The way the software provider addresses this issue is with an 
escalating series of Ad Failure Nags. These will continue for two weeks or until the 
software receives ads. For every two days the software does receive ads, the software 
will decrement the Ad Failure Nag timer by one day. If the timer runs out, the software 
will display an apology to the user, revert to the Freeware version, and mark the user's 
software as owned by a Deadbeat User. Deadbeat Users will only be allowed to return 
to Adware if the ad server can be connected to at the time the user attempts to return to 
Adware. See Figs. 17A -17C. It should be noted that if the software provider should 
ever decide to retire Eudora and wish to let people use it without ads, the software 
provider can simply publish a permanent registration code. 

[0157] Alternatively, the e-mail client advantageously includes several more 

sophisticated functions for determining that an ad failure condition requires the 
employment of the Ad Failure Nag discussed above. For example, the client device can 
identify an ad download failure condition when a corresponding ad download function 
has failed to downloads during a predetermined period of time. In addition, the e-mail 
client device can identify an ad display failure condition when a corresponding ad 
display function has failed to display ads for a predetermined time period, e.g., the 
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time(s) specified in the New PlayList received from the PlayList server and/or the 
current PlayList(s) stored for use by the e-mail client device. Either condition invokes 
the Ad Failure Nag function discussed above. 

[0158] One of the things the software provider will need to know is that the ads the 

software provider thinks are being displayed are actually being displayed, thus 
confirming that the ads are being displayed as frequently and for as long as the software 
provider thinks they are being displayed. It will be appreciated that this will be crucially 
important to maintaining credibility with advertisers. An exemplary audit scheme 
contains the following features: 

[0159] • Keep a rotating log of ad displays. This log will be rolled over once per week. 
The log will record ad-related events—when an ad was displayed, when it was removed, 
and when it was clicked on— in addition to other events, like cumulative face time in 
Eudora, cumulative run time, etc. 

[0160] • At random, ask the user for permission to transmit the log. At a frequency of 
one out of every hundred users per month, ask for the user's permission to return the log 
to the software provider. If the permission is given, the log will be formatted in ASCII, 
placed in an outgoing message, and queued. The user will be given the opportunity to 
inspect and, if he/she desires, cancel the log collection. See Fig. 18 A. 

[0161] • For selected users, deliver a pastry. In addition to the random send of the log, 
the software provider will also, at random, ask particular users for their permission to 
audit transactions in detail with the server. This will allow the software provider to 
correlate client and server behavior. 

[0162] Additional details on instrumentation applicable to the exemplary Eudora e-mail 

client software is provided in Figs. 18B -18E. 

[0163] The various state flow diagrams illustrated, for example, in Figs. 5A, 6A, 7A, 8 

and 9, referred to a plurality of web pages, i.e., HTML pages that can be accessed and 
retrieved from one of the software provider's servers, e.g., registration server 301. See 
Fig. 1. The general purposes of these pages and the URNs which the software uses to 
access these pages will now be described in greater detail below. 

[0164] It will be appreciated that it will be helpful for the client to give the server 

information to help the server direct the user to the proper location or to assist the user 
by prefilling certain items on Web page based forms. That is the function of the query 
part of the URNs. The elements that might go in query parts are listed below. It will be 
noted that the query parts are divided into two groups. The first group includes items 
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which are considered personal, and great care should be taken to transmit them only 
when appropriate; the second group includes items which are not considered to be 
privacy-sensitive. 



Realname 


The Real Name field from the user's Dominant e-mail 
personality. \n,r*+ supports multiple e-man personalities 
for IMAP4 (both POP3) e-mail accounts.) 


Regfirst 


The first name under which the user registered last time (if 
any). 


Reglast 


The last name under which the user registered last time (if 
any). 


Regcode 


The user's current Eudora registration code (if any). 


OldReg 


The user's old-form RegCode. 


e-mail 


The e-mail address from the user's Dominant personality. 


Profile 


The profile information the user has entered. 


Destination 


This is the URN which the user wishes to visit. 


Adid 


This is the id of an ad on which the user clicked. 


Platform 


MacOS, Windows, Palm, Nintendo 64, etc. 
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Product 


The software provider's code name for the product being 
registered, riudora, rJJijJVlail, etc. 


Version 


The version number of the product being used to register. 
This should be of the form Major.Minor.Bugfix.Build. 


DistributorlD 


This will be a code which sites may apply for, which will, 
in turn, allow the site, i.e., its controlling entities, to 
receive a continuing revenue stream in return for 
providing users with this custom-branded copy or Eudora. 


Action 


What it is the user has requested to do; register, pay, 
lostcode, etc. 


A n 

jviocie 


xiitner Fayware, Aaware, or .freeware. 


Topic 


Used for support items, this tells the server what particular 
kind of support is needed. 



[0165] Typically, all of the software provider's non-ad URNs begin with: 



http://jump.eudora.com/jump. cgi?action=whatever 
[0166] The "action" value determines what function the user wishes to perform. The 

software provider then appends various other query parts to the URN, suitably %- 
escaped, i.e., separated by a percentage (%) or ampersand (&) symbol (for example), 
according to the chart illustrated in Fig. 19. A brief discussion of each type of web page 
referenced in Fig. 19 is provided immediately below. 



PAYMENT 
WEB PAGE 



This web page should take the user's credit card info, 
name, e-mail address, and whatever other 
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information the software provider wants to compile 
about its users. It will also ask them for a question 
and answer for use if they ever lose their payment 
code. It should return, e.g., display and also e-mail, 
their official registration name and registration code. 


FREEWARE 
REGISTRATION 
WEB PAGE 


This web page should take the same info as the 
Payment web page, minus the credit card 
information. It should send back (that is, display and 
also e-mail) their official registration name and 
registration code. 


ADWARE 
REGISTRATION 
WEB PAGE 


This web page should take the same info as the 
Payment web page, minus the credit card 
information. It should send back (that is, display and 
also e-mail) their official registration name and 
registration code. 


BOX REGISTRATION 
WEB PAGE 


This web page exists to accept registrations 
generated by Box or updater installers. It should 
simply accept the user's code, validate it, mail it 
back, and display a "thank you for registering" page 
or dialog box. 


LOST CODE 
WEB PAGE 


This web page helps users find their registration 
codes. When they register/pay, they'll be asked to 
provide their name, e-mail address, and a question 
and answer. When they come to the lost code page, 
they'll be asked for name and address, and if that 
matches, they'll be asked their question. If all that 
goes well, their RegCode will be mailed to them. If 
they can't receive mail, they'll have to call. 
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UPDATE 
WEB PAGE 


This web page should list the updates that are 
available to the user. Ideally, it would list only those 
updates the user does not already have, and clearly 
indicate which updates are free and which updates 
the user needs to pay for. This web page will be 
downloaded to the user's system from time to time 
and displayed "off-line" in Eudora, and so it should 
be kept small. 


ARCHIVED VERSIONS 
WEB PAGE 


This web page should list all versions of Eudora, so 
that users can download whatever they happen to 
need. 


PROFILE WEB PAGE 


The purpose of this web page is to collect 
demographic information so that ads delivered to the 
user can more precisely targeted by advertisers. At 
this page, the user will be asked a series of questions 
about his/her personal preferences, habits, etc., e.g., 
buying habits, sleeping habits, preferences in 
clothing, etc. No information identifying the user is 
to be collected on this page! The information will be 
reduced to a cookie, mailed to Eudora and stored as 
part of the user's settings in the Eudora directory 
(folder). The procedure for accepting a profile is the 
same as the procedure for accepting a registration 
code, detailed below. 


SUPPORT WEB PAGES 


The software provider will need several web pages 
for resolving user problems. For these pages, the 
software provider will use the "topic" part of the 
query to direct users to situation-specific help as 
needed. 
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[0167] Having discussed the client side of the overall system illustrated in Fig. 1, is it 

now time to turn to the server side of the system. The network will not be discussed in 
detail, however, as it is something well known in the art. 

[0168] In particular, the PlayList Server (PLS) or Servlet, i.e., the applet responding to 

the PlayList Request, shall now be described in detail. The PLS is a server side program 
which services HTTP requests and returns HTTP responses. It will be appreciated that 
each request launches a different thread, and that the data format of communications 
between the client and the PLS is XML-encoded in the exemplary embodiment. The 
PLS advantageously can be instantiated using the following Java® packages. 



PKG 


DESCRIPTION 


USAGE 


XP 


XP is an XML 1.0 parser written in Java. 


The PLS uses the 




The parser checks a given XML 


XP parser for: 




document for well-formedness and 


1. parsing the client 




validity. Additional information is 


request to ensure 




available from 


that it is valid. 




http://www.jclark.com/xml/xp/. 


2. parsing the 






PlayList Response 






to ensure that it is 






valid 


SAX 


SAX (Simple API for XML) is a standard 


The PLS uses the 




interface for event-based XML parsing, 


SAX interface both 




the parser reads the XML document line 


in the XML request 




by line and initiates events that contain 


and the XML 




information about the line that was just 


response. In the 




read. The PLS listens to particular events 


request, the PLS 




of interest and extract the data from the 


"looks" for specific 




XML document in that way. Additional 


tags to build the 




information is available from 


request object. In 
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http://www.megginson.com/SAX/ 


the response, the 






PLS sends events 






to generate the 






PlayList XML 






response. 


MM.MySQL 


MM.MySQL is a Java Database 


The PLS use the 




Connectivity (JDBC) Type-4 driver, i.e., 


JDBC methods to: 




an all-Java driver that issues requests 


L Establish 




directly to the PlayList server database. It 


connection(s) to 




will be appreciated that this is the most 


communicate with 




efficient method of accessing the 


the database using 




database. The JDBC API is made up of 


JDBC. PLS first 




classes and interfaces found in the 


establishes a 




Java.sql and Java.text packages. 


connection through 




Additional information is available at 


the appropriate 




http://www.worldserver.com/mm.mysql/ 


JDBC driver. The 






connection object 






can be used to 






perform all 






operations on the 






given database. In 






an exemplary case, 






the PLS will create 






a pool of 






connection objects 






during the Servlet 






initialization. 






2. Execute SQL 






statements and 






retrieve results the 






PLS performs a 






SQL query to the 
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database using both 






Statement and 






Prepared Statement 






objects. 



[0169] What follows is an explanation of task flow in the PLS when the Servlet doPost 

method is invoked. See Fig, 20. The PLS parses the XML request and builds objects 
that represents the client update request. It will be noted that data access is performed 
using SAX. When logging the client request, the PLS stores the client request 
information in a so-called ClientUpdate table (not shown). 

[0170] It will be appreciated that the PlayList Request can be received from a plurality 

of e-mail clients residing on the client computers generally denoted lOOn through any 
given day. When issuing the same SQL statement repeatedly, it will be appreciated that 
it is more efficient to use a Prepared Statement rather then generating a new Statement 
in response to a query. In the logging operation, the software provider advantageously 
can employ the following semantic to avoid repetitive Statement generation: 

[0171] PreparedStatement ps = conn.prepareStatement("INSERT INTO ClientUpdate 

(date, userAgent, PlayListId,Y) values (?, ?, ?, ?,..)"); 

[0172] It should be mentioned that in generating a New PlayList, the Servlet 

advantageously can employ both SQL queries and programming filtering. It will also be 
appreciated that these processes are synchronized in order to prevent conflicts when 
accessing the database. Appropriate pseudo code of generating a PlayList is depicted in 
Figs. 21 A and 21 B. The first block of pseudo code in Fig. 21 A generates an ad list. It 
will be appreciated that the ad list generated by the first block of pseudo code holds all 
the image ads that are active and can be delivered within a predetermined time frame. 
The second block of pseudo code listed in Fig. 21 A calculates the time needed to deliver 
the ads. The third block of pseudo code, which is illustrated in Fig. 21B, determines 
additional ads which can be used to fill the available facetime. In other words, if the e- 
mail client software has remaining time to fill, the generated PlayList will automatically 
fill the available time with runout ads, i.e., find a run out ad which is not in the ads 
history and which also fits into the Goal show time left. 

[0173] When generating XML, it is often useful to generate comments, processing 

instructions, and so on. The package XP Writer provides a set of methods for creating 
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specific kinds of nodes in the output XML code, i.e., file. The following is a short list of 
methods PLS employs in generating the XML output. 
[0174] Starts an element - start-tag 

[0175] © Ends an element - end-tag or close the current start-tag as an empty 

element. 

[0176] • Attribute add attributes to a tag name value pair format 

[0177] • Comments writes a comment 

[0178] The PLS stores the information generated in response to a request in two tables, 

a PlayList general response table, which holds the client info section and PlayList 
general information, and a PlayList specific response, which holds the entry section. It 
will be appreciated that the PLS advantageously can use the prepared statement API to 
optimize performance in response to a query. 

[0179] Referring again to Fig. 20, that figure illustrates a class diagram which 

advantageously describes the representation and rendering of the PlayList, as will as the 
PlayList Response. It will be appreciated that this class diagram includes repeated 
XML Write method calls; these method calls are employed by PLS to generate the 
XML tags associated with the PlayList. 

[0180] Turning now to Fig. 22, that figure illustrates the major PlayList Servlet Classes, 

which collectively define the PlayList Servlet. More specifically, the PlayList Request 
class handles the request and subsequently maps the XML request to the clientUpdate 
object while the PlayListResponse class handles the response and writes the 
clientUpdateResponse back to the client. In addition, the PlayListsGenerate class 
generates the PlayLists while the DBManager class handles the Data Base connection 
pool. Additional details are readily apparent from Fig. 22. 

[0181] It will be appreciated from Fig. 23 that all of the storage operations employing 

the database advantageously can be threaded. As mentioned above, all actions with 
respect to the database are performed the MM.MySQL package. 

[0182] In summary, one exemplary embodiment of the present invention encompasses 

software for converting a general purpose computer into a specialized PlayList server 
for supplying a PlayList Response to a client device for exchanging information with an 
information server system over a communications network and storing ads. More 
specifically, the software instantiates a PlayList Response generation function for 
generating a PlayList Response identifying a plurality of selected ads to be presented by 
the client device, and a first communications function that completes a PlayList 
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Response send communication link with the client device via the communications 
network over which the PlayList Response is transmitted to the client device, wherein 
the information server system and the PlayList server are independently controlled. It 
will be appreciated that, while the PlayList directs the presentation, e.g., display, of ads 
on the client device, e.g., an e-mail client, the ads advantageously may be delivered to 
or retrieved by the client device in any number of ways in this preferred embodiment. In 
this exemplary embodiment, the PlayList Request preferably includes ad identifiers and 
ad presentation instructions; corresponding uniform resource names (URNs) can be 
included but may be omitted. 

[0183] According to another exemplary embodiment, the present invention 

encompasses software for converting a general purpose computer into a specialized 
PlayList server for supplying a PlayList Response to a client device exchanging 
information with an information server system and receiving ads from an ad server over 
a communications network. The software advantageously includes a PlayList Response 
generation function for generating a PlayList Response identifying a plurality of 
selected ads to be presented by the client device, and a first communications function 
that effects a PlayList Response send communication link with the client device via the 
communications network over which the PlayList Response is transmitted to the client 
device. Preferably, the information server system and the PlayList server are 
independently controlled. It will be appreciated that this exemplary and non-limiting 
embodiment of the present invention contemplates a specific communications channel 
between the client device and a dedicated ad server (system) for delivery of ads defined 
by the PlayList. It will also be appreciated that the PlayList Request employed by this 
exemplary embodiment includes both information dictating presentation of the ads 
and/or operation of the client device with respect to ad presentation functions, and the 
name and URN for ads included in a New PlayList. 

[0184] According to yet another exemplary embodiment, the present invention provides 

software for converting a general purpose computer into a specialized PlayList server 
for supplying a PlayList Response to a client device exchanging information with an 
information server system and receiving ads from an ad server over a communications 
network, including: 

[0185] • a PlayList Response generation function for generating a PlayList 

Response identifying a plurality of selected ads to be presented by the client device, 
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[0186] a Play Li st Request parsing function for extracting selected information 

from the PlayList Request; 
[0187] a PlayList generation function receiving an output of the database driver 

function for generating a PlayList for inclusion in the PlayList Response which 

identifies a plurality of selected ads to be presented by the client device in response to 

receipt of a PlayList Request, 
[0188] • a selected information supply function for supplying the selected 

information to the PlayList Response generation function to thereby initiate the PlayList 

generation function, 

[0189] • a first communications function that effects a PlayList Response send 

communication link with the client device via the communications network over which 
the PlayList Response is transmitted to the client device, and 

[0190] • a second communication function that effects a PlayList Request receive 

function with the client device via the communications network, 

[0191] • wherein the information server system and the PlayList server are 

independently controlled. 

[0192] Preferably, the PlayList Request parsing function includes an extensible markup 

language (XML) parsing function for verifying the wellformedness of the PlayList 
Request, a PlayList analysis function receiving the PlayList Request after verification 
by the XML parsing function for generating an object, and a database driver function 
receiving the object for building a query from the object and applying the query to a 
PlayList server database. 

[0193] It should be noted that the PlayList Response generation function is initiated by 

receipt of a PlayList Request, which, in an exemplary case, includes the name of the 
current PlayList(s) employed by the client device providing the PlayList Request. 
While each of the numerous client devices connected to an information server generate 
a PlayList Request, the discussion of this specific aspect of the present invention, i.e., 
the PlayList server, can best be understood from the point of view of a system including 
only one client device; the actual implementation of the, for example, e-mail client 
device contemplates the use of thousands of client devices. 

[0194] The PlayList Request advantageously can include information regarding the 

currently running PlayList(s) on the client device, and user data fields that store data 
regarding the progress made by the client device in presenting, e.g., displaying, the ads 
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stored by the client device. An exemplary and non-limiting list of the information that 
can be provided to the PlayList server via the PlayList Request includes: 

[0195] • a first user data field identifying a current PlayList; 

[0196] • a second user data field identifying user demographic data; 

[0197] • a third user data field identifying user/client device behavior data; 

[0198] • a fourth user data field identifying usage history of the client device; 

[0199] • a fifth user data field identifying the respective software operating on the 

client device; 

[0200] • a sixth user data field identifying the respective operating system of the 

client device; 

[0201] • a seventh user data field identifying the amount of time the user has used 

client device over a prescribed time interval; 

[0202] • an eighth user data field identifying the total amount of display time 

required for the stored ads that remain to presented by the client device; 

[0203] • a ninth user data field identifying the total amount of times that ads were 

presented by the client device during the prescribed time interval; 

[0204] • a tenth user data field identifying the dimensions of a display screen 

associated with the client device; and 

[0205] • a list of the ad identifiers corresponding to advertisements that have been 

displayed in the prescribed most recent time interval. 

[0206] Advantageously, the PlayList Request parsing function can extract selected 

information from the PlayList Request and employ the selected information and other 
information, e.g., information provided by the entity controlling the PlayList server, in 
generating the PlayList Response. It will be appreciated that the PlayList Request may 
include all or a subset of the information listed immediately above; the PlayList Request 
parsing function extracts information contained in at least one of the user data fields. In 
any event, the receipt of the PlayList Request by the PlayList server initiates generation 
of the PlayList Response. 

[0207] In response to the PlayList Request, the PlayList Response generation function 

generates one of an action command and the PlayList Response. With respect to the 
former, the PlayList Response generation function advantageously can generate the 
action command in response to receipt of a garbled PlayList Request. This can be 
generally thought of as an error code directing the client device to send a New PlayList 
Request. It will be appreciated that the action command can include an associated error 
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message, which is presentable to the user by the client device. Alternatively, the action 
command may cause the client device to delete all of the ads received and/or stored by 
the client device responsive to a command issued to the PlayList server by an entity 
controlling the PlayList server. In other words, there are times when the software 
provider may wish to flush the existing ads; the entity controlling the PlayList server, 
e.g., the software provider, sends a command to the PlayList server, which command 
causes the PlayList server to respond with a flush command to either specific PlayList 
Requests, e.g., PlayList Requests generated by a particular software version, of all 
PlayList Requests, With respect to the latter, a detailed discussion follows. 

[0208] As discussed above, the PlayList Response advantageously includes both client 

information, information regarding how the client device, e.g., a PDA device, is to 
present, e.g., display, the selected ads, i.e., the ads that during the time period following 
receipt of the PlayList Response by the client device, and a New PlayList. For example, 
selected parameters included in the client information advantageously can switch the 
client device from between a persistent presentation mode and a short-lived presentation 
mode of presenting the ads. The client information can, in an exemplary case: 

[0209] • control the turnover rate of the ads presented by the client device; 

[0210] • specify the periodicity at which the client device generates the PlayList 

Request; 

[021 1] • establish a minimum time separation between competing ones of the ads; 

[0212] • establish specifications directing the manner in which the client device is 

to present each of the ads. 

[0213] For example, when the ads available to the client device include both current ads 

(paid ads) and expired ads (free ads), the client information includes a minimum time 
period during which the client device presents the current ads before the client device 
presents the expired ads. The client information may also establish a maximum time 
period during which the client device is permitted to present the expired ads. In any 
event, the PlayList Response advantageously may include commands or selected 
parameters which direct the client device to either concatenate the New PlayList to the 
current PlayList(s) or discard the current PlayList(s) in favor of the New PlayList. The 
command, or the selected parameters, controlling this facet of the client device 
operation is executed upon receipt of the PlayList Response by the client device over 
the effected communications link. 
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[0214] The New PlayList included in the Play List Response includes a name and a 

corresponding Uniform Resource Name (URN) for each of the selected ads. It will be 
appreciated that the URN can correspond to one of a storage location of the respective 
named ad on an ad server or a location on the ad server redirecting the client device to a 
location on another storage device for the respective named ad. Alternatively, the URN 
specifies a location on the ad server redirecting the client device to an ad storage 
location collocated on the ad server for the respective named ad. It should be mentioned 
at this point that, in addition to the name and URN of each of the selected ads, the New 
PlayList may also include information identifying an ad type, i.e., postage stamp ad, 
toolbar ad, or placard ad, for each one of the respective selected ads. 

[0215] It should be noted that in at least one exemplary embodiment of the present 

invention, the PlayList server instantiated by software stored on the server computer 
302 advantageously responds to a PlayList Request written, i.e., coded, in extensible 
markup language (XML). One of ordinary skill in the art of documents generated in 
XML will appreciate that these documents, e.g., the PlayList Request, advantageously 
can have an associated document type definition (DTD). In order to optimize system 
performance, the PlayList server should have the DTD available, i.e., available to the 
PlayList Request parsing function. There are several options for ensuring that the DTD 
is available to the PlayList server. First, the DTD for each of different types of client 
devices, e.g., e-mail client device or PDA, is stored by the PlayList server. In that case, 
the PlayList Request need only include a DTD tag, which identifies the particular DTD 
to be employed by the PlayList Request parsing function. Second, the DTD 
advantageously can be embedded in the PlayList Request. In either case, both the 
PlayList server and the client device implicitly use the same DTD. 

[0216] It should be mentioned that the software provider should make provisions with 

respect to ad security. There are really two security issues to consider. One is whether or 
not the client is getting valid ads (call this client security), and the second is whether or 
not a valid client is fetching ads (call this server security). 

[0217] Client security is of relatively small importance. If a given person manages to 

trick Eudora into displaying some ads other than those transmitted by the software 
provider, it probably doesn't matter a great deal. This is not to say that it could not 
become problematic if large numbers of clients at one or more sites began doing it; 
however, a carefully worded license agreement should make at least large sites avoid 
actions which would cause this particular problem. However, to avoid trivial attacks, 
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PlayLists and ads advantageously can be checksummed with MD5 (or another 
mechanism), and the checksums recorded in the PlayList. Then the client can checksum 
the PlayList and ads using the same secret seed, and compare its checksums to those in 
the PlayList. If it fails to get the proper ads, this will be treated as a failure to get ads at 
all. 

[0218] Server-side security is potentially a much bigger problem. The software 

provider intends to charge advertisers for ads, based on the understanding that the 
software provider's users will actually see the ads the software provider is charging for. 
To do this with confidence, the software provider should ascertain that it is actually 
Eudora that is downloading the ads, and not some rogue process written to fetch many 
ads. Why would someone bother to fetch ads? While the software provider can't 
discount the "because they can" motivation of the amateur hacker, the real issue is the 
ad revenue, i.e., ad bounty. Because every ad fetch can generate revenue for a third 
party, there is a very significant financial incentive for that third party to cause a lot of 
ad fetches. It thus becomes imperative that the software provider prevent (and/or detect) 
ad fetches not made by copies of Eudora. Given that such fetches may be in violation of 
the agreement the software provider signed with the distributor, these fetches could 
constitute a form of fraud. 

[0219] There are several different approaches to fraud detection which advantageously 

can be implemented in the software running, for example, on Ad server 303. Whatever 
method the software provider eventually uses to prevent fraud, it will be important also 
to detect fraud should it occur. There are two broad classes of fraud detection; 
authentication and statistical analysis. 

[0220] Authentication is easily understood; if the program fetching the ads fails to 

prove that it is a valid copy of Eudora, the software provider will be alerted to possible 
fraud. However, authentication provides challenges of its own, and may be impossible 
or impractical or simply unnecessary. 

[0221] Statistical analysis has some significant benefits, but also significant drawbacks. 

The benefits include minimal work in the client (and hence no vulnerability to 
disassembly, etc.), no run-time burdens on either the client or the server, i.e., everything 
can be done "after the fact" during accounting runs, easily changeable from the software 
provider's end, ability to be applied retroactively, etc. The drawbacks to statistical 
analysis include that statistical analysis will never be entirely certain, and that the 
software provider may not collect the proper statistics, etc. 
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[0222] A listing of parameters or statistical measures that the software provider may 

gather or compute is presented immediately below. 



ClientID 


It's hard to see a way to avoid generating some sort of client id 
for use with fetching ads. The software provider might hope that 
such identifiers will be self-validating, but it is preferable that the 
software provider needs to know what particular installation of 
Eudora is actually fetching ads. This can then be used in 
compiling statistics and performing computations. By 
"installation" the software provider means a single storage 
system directory (PC) or folder (Mac) with a Eudora mail 
structure in it, i.e., data interchanged between the e-mail client 
and at least one server and not necessarily the e-mail client itself, 
per se. 


IpAddress 


The software provider will likely want to log requests by the IP 
address of the originating e-mail client. 


DistributorlD 


Of course a cornerstone of the referral payment system is the fact 
that the software provider will record the distributor ED for the 
client fetching ads. The software provider should collect this 
wnen users pay or even register trie software. 
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ID. 


NumClientlDs 


This statistic is the number of client ID's with a given distributor 
ID. 


NumAdsFetched 


The number of ads fetched by a particular client ID. 
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[0223] Given the raw data available from monitoring the parameters listed above, the 

following is an exemplary and non-inclusive list of possible statistical measures which 
can be generated. 



NumAdsFetched 


A client ID with a very high number of ads fetched is 
suspicious. 


NumClientlDs/ 
NumPaidUsers 


Paid users is a very hard number, because the software 
provider will have collected credit card information and 
charged against this card. Thus, it can serve as a useful 
measuring stick for how many clients the software provider 
can expect. A particular distributor with a very high ratio or 
a ratio that suddenly goes higher bears investigation. 



[0224] One of the issues which the software provider must be very cognizant of is the 

protection of the user's privacy, i.e., the user generally does not want to receive ads 
based on information that the user unknowingly submitted to the software provider. 
There is an extremely vocal and paranoid subset of the user community, who object to 
practically all forms of information gathering, even the most benign. Even relatively 
innocent devices like serial numbers are considered something to be completely 
avoided. While the serial number of a software program may seem like a trivial matter 
to the software supplier, users who object to this type of "tagging" exist, and the 
software provider should be cognizant of such users. In order to avoid such concerns to 
the maximum extent possible, the software provider should adopt a Confidential 
Information Policy which includes the following provisions: 

[0225] • Obtain Permission - Before the software provider gathers or transmits 

any data that might identify the user to the advertiser, the software provider should 
obtain the user's explicit (See Fig. 18A) or near-explicit permission. The term near- 
explicit is employed to denote that the software provider may, for example, put a special 
privacy warning in the web page where the user registers a software program such as 
Eudora. Here, the user is clearly taking an action to submit data to the software 
provider; as such, explicit permission shouldn't be needed. On the other hand, the 
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software provider should go out of its way to identify areas where an unreasonable user 
might be able to claim that he/she didn't know he/she was giving information to the 
software provider, and ask for explicit permission there, even if it seems relatively 
obvious to the software provider. 

[0226] • Data Separation - Insofar as possible, the software provider should 

maintain payment information separate from registration information, and both types of 
information should be maintained separate from demographic information, etc. While it 
may be very tempting to correlate databases, the software provider faces potential 
crucifixion if the databases are actually correlated. Moreover, since the software 
provider can still deliver very targeted advertising without database correlation, the 
software provider should maintain separate databases. 

[0227] • User Verifiability - Insofar as possible, protections established by the 

software provider should be verifiable by end users with packet sniffers. The software 
provider may even encourage the practice of watching the software's, e.g., Eudora's, 
actions. It is one thing to say "The software provider does not give your personal data to 
advertisers;" it is quite another for the user to be able to verify that this is the case. 

[0228] • Strong Public and Private Commitment - The software provider needs 

to be clear and public with its privacy policies, and the software provider needs to 
respect them internally. If the software provider merely views privacy as something the 
software provider must do to avoid adverse press coverage, the software provider will 
do it poorly and wind up in trouble. 

[0229] In summary, the present invention encompasses a multi-moded software 

product, e.g., e-mail software, which includes three "self-contained" different versions 
(or, "modes"), including a "first full feature set" version which is activated when the 
software product is paid for by the user (i.e., a "Payware version"), a "second full 
feature set" version which is activated when the user agrees (e.g., either by default or by 
explicit agreement) to accept advertisements delivered to the client device in order to 
subsidize the software product (i.e., an "Adware" version), and a "reduced feature set" 
version which is activated when the software product is not paid for (i.e., a "freeware" 
version) and the "second full feature set" version is not activated. The present invention 
also encompasses a system and method for automatically distributing advertisements to 
a multiplicity of client devices that have such multi-moded software installed thereon. 
It will be appreciated that the first and second full feature sets are identical with respect 
to e-mail support features; it will also be appreciate that the second full feature set 
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includes PlayList and ad fetching and display features which are dormant in the first full 
feature set. 

[0230] Moreover, the present invention further encompasses multi-moded software as 

set forth above, wherein the multi-moded software includes a mode switching function 
which automatically switches from the "Adware" version to the "freeware" version upon 
detecting a prescribed condition (e.g., based upon monitored user activity level, and/or 
less than a prescribed number of ads having been downloaded, i.e., "deadbeat user" 
criterion). The present invention also encompasses a system and method for 
automatically distributing advertisements to a multiplicity of client devices that have 
such multi-moded software installed thereon. 

[0231] It will be appreciated from the discussion above that the present invention 

further encompasses multi-moded software as set forth above, wherein the multi-moded 
software includes a mode switching function which automatically switches from the 
"Adware" version to the "freeware" version upon detecting occurrence of a prescribed 
"ad failure condition", e.g., less than a prescribed number of ads having been received 
and/or displayed by the client device within a prescribed time period, and an "Ad 
Failure Nag" function which monitors "time since last Nag" and which generates an "Ad 
Failure Nag" according to a "Nag Schedule" which is dynamically varied based on the 
monitored "time since last Nag" information and/or based on cumulative ad 
download/di splay statistics or information. The present invention also encompasses a 
system (and method) for automatically distributing advertisements to a multiplicity of 
client devices that have this multi-moded software product installed thereon. 

[0232] In one exemplary embodiment, the present invention further encompasses multi- 

moded software as set forth above, wherein the multi-moded software includes a Nag 
function which generates different types of Nags dependent upon the current mode of 
the software product which is currently activated, and/or based upon time since the last 
Nag was generated, and/or based on cumulative ad download/display statistics or 
information, and/or based on other monitored conditions. For example, the different 
types of Nags could include a "Registration Nag", a "Payware Nag", an "Adware Nag", 
an "Update Nag", and an "Ad Failure Nag". The present invention also encompasses a 
system (and method) for automatically distributing advertisements to a multiplicity of 
client devices that have this multi-moded software product installed thereon. 

[0233] In another exemplary embodiment, the present invention encompasses a 

software product (e.g., e-mail software) that incorporates an automatic advertisement 
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download function for automatically downloading advertisements to be displayed when 
the software is activated, and a control function for monitoring user activity levels and 
for controlling the display of downloaded advertisements at the client device based upon 
the monitored user activity levels (e.g., based upon "discrete" and/or "cumulative" ad 
display parameters). The present invention also encompasses a system and method for 
automatically distributing advertisements to a multiplicity of client devices that have 
this software product installed thereon. 

[02341 The present invention also encompasses an e-mail software product that 

incorporates a control function for automatically downloading advertisements from a 
remote server system which is separate and independent from the e-mail server system, 
as well as the system and method for automatically distributing the advertisements to 
client devices which have this e-mail software product installed thereon. In particular, 
the system includes an ad server system that manages, administers, and controls the 
distribution of advertisements, and which is controlled by a control entity (e.g., one 
operated by the present assignee, QUALCOMM INCORPORATED) which is separate 
and independent from the control entity which controls the e-mail server system which 
provides e-mail services to any particular client device which has this e-mail software 
product installed thereon. Thus, in sharp contrast to the Juno Online Services system, in 
accordance with this aspect of the present invention, the ad server system and the e-mail 
server system are operated independently, i.e., under the control of separate and 
independent control entities. 

[0235] Advantageously, the present invention also encompasses a software product, 

e.g., e-mail software, which incorporates an automatic advertisement files download 
function for automatically downloading advertisements from a remote server system to 
a client device on which the software product is installed, and a control function for 
locally controlling the display of downloaded advertisements at the client device based 
upon ad parameters included in the downloaded advertisement files, e.g., including (for 
each ad), various combinations and sub-combinations of the following ad parameters, 
namely, the maximum ad display time, or face time, for any given display of that 
particular ad, the maximum total/cumulative ad display time, or face time, for that 
particular ad, the maximum number of times to display that particular ad per day, the 
date/time before which that particular ad should not run, and the date/time after which 
that particular ad should not run. The present invention also encompasses a system and 
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method for automatically distributing advertisements to a multiplicity of client devices 
that have this software product installed thereon. 

[0236] It will be appreciated that the present invention also encompasses a software 

product, e.g., e-mail software, which incorporates an automatic advertisement download 
function which fetches a PlayList from a remote server system (e.g., a PlayList server 
system) which specifies the advertisements to be fetched by the client device on which 
the software product is installed and the source addresses (e.g., URNs) of the ad servers 
on which the specified advertisements are stored, fetches the advertisements specified in 
the fetched PlayList, and stores the fetched advertisements on the client device. The 
present invention further encompasses a system and method for distributing 
advertisements to client devices which have this software product installed thereon, 
including a PlayList server (or PlayList server system) which, in response to a PlayList 
Request from a particular client device that includes a client PlayList identifier, 
compares a client PlayList identified by the client PlayList identifier with a current 
PlayList (which may optionally be customized to that particular client device) stored on 
the PlayList server, and then sends back to the client device a New PlayList which 
specifies the new advertisements to be fetched by the client device, and the source 
addresses of the ad servers on which the specified new advertisements are stored. 

[0237] Optionally, the above-described automatic advertisement download function of 

the software product installed on the client device can delete (discard) all or PlayList 
server-specified ones of the advertisements which are currently stored on the client 
device, e.g., those which are not specified in the current PlayList; and/or the above- 
described automatic advertisement download function of the software product installed 
on the client device can merge the New PlayList with the current client PlayList. The 
present invention also encompasses several variations and details of implementation of 
this novel PlayList/ad fetch process utilized in the Eudora Adware scheme. 

[0238] Moreover, the present invention encompasses a software product, e.g., e-mail 

software, which incorporates a custom installer which identifies the specific software 
product distributor that distributed that software product. The present invention further 
encompasses a software product, e.g., e-mail software, which incorporates an automatic 
advertisement download function for automatically downloading advertisements from a 
remote server system to a client device on which the software product is installed, and a 
custom installer which identifies the specific software product distributor which 
distributed that software product, for the purpose of facilitating apportionment of 
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advertising revenue the software product vendor receives from advertisers to specific 
software product distributors. The present invention also encompasses a system (and 
method) for automatically distributing advertisements to a multiplicity of client devices 
which have this software product installed thereon, wherein the system includes a 
centralized control facility which receives software product distributor ID information 
from the client devices and uses this software product distributor ID information to 
facilitate apportionment of advertising revenue the software product vendor receives 
from advertisers to specific software product distributors. Alternatively, or additionally, 
a central database function which identifies (e.g., by means of cross-referencing and/or 
correlation tables) the software product distributor ID for each software product 
distributed by the software vendor, e.g., based on a serial number or reference code 
associated with each copy of the software product, can be utilized. 
[0239] Furthermore, the present invention encompasses a software product, e.g., e-mail 

software, that incorporates an automatic advertisement download function for 
automatically downloading advertisements from a remote server system to a client 
device on which the software product is installed, and a control function which utilizes a 
built-in "deadman timer" to impose a time limit for each particular advertisement 
download session, e.g., the client device will be disconnected from the remote server 
system upon expiration of the time limit imposed by the "deadman timer". The present 
invention also encompasses a system (and method) for automatically distributing 
advertisements to a multiplicity of client devices that have this software product 
installed thereon. 

[0240] It will also be appreciated that the present invention can be characterized as a 

software product, e.g., e-mail software, that incorporates an automatic advertisement 
download function for automatically downloading advertisements from a remote server 
system to a client device on which the software product is installed, and an 
instrumentation and auditing module having various novel features/functions, e.g., 
maintaining a rotating log of ad-related statistics and/or performing random and/or 
statistically-based ad effectiveness audits with user permission. The present invention 
also encompasses a system (and method) for automatically distributing advertisements 
to a multiplicity of client devices that have this software product installed thereon, 
wherein the system includes a centralized control facility for obtaining ad-related 
statistical information from selected client devices, in a random or statistical manner, 
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e.g., for the purpose of monitoring the integrity and/or effectiveness of the 
advertisement distribution system. 

[0241] Moreover, the present invention encompasses a software product, e.g., e-mail 

software, that incorporates an automatic advertisement download function for 
automatically downloading advertisements from a remote server system to a client 
device on which the software product is installed, and a "link history' 1 function which 
enables the user to review previously-viewed advertisements, e.g., by providing a 
graphical user interface (GUI) which includes a link history window that lists links the 
user has previously visited and ads that have been previously displayed to the user, 
along with some status information on each. Preferably, a mechanism will be provided 
to enable the user to select an ad listed in the link history window for display, e.g., by 
single-clicking the appropriate ad link, and to enable the user to visit the source Web 
site of any given ad listed in the link history window, e.g., by double-clicking the 
appropriate ad link. The present invention also encompasses a system (and method) for 
automatically distributing advertisements to a multiplicity of client devices that have 
this software product installed thereon. 

[0242] Furthermore, the present invention encompasses a software product, e.g., e-mail 

software, which incorporates a "Nag" function that monitors "time since last Nag" and 
that "nags" the user according to a "Nag Schedule" which is dynamically varied based 
on the monitored "time since last Nag" information. 

[0243] Finally, the present invention encompasses a software product, e.g., e-mail 

software, that incorporates a download function that downloads separate file portions 
representing a single image during separate communication sessions with a remote 
server (e.g., separate file portions of an advertisement file, e.g., a GIF file). The present 
invention further encompasses a system (and method) for automatically distributing 
advertisements to a multiplicity of client devices that have this software product 
installed thereon. 

[0244] Although presently preferred embodiments of the present invention have been 

described in detail hereinabove, it should be clearly understood that many variations 
and/or modifications of the basic inventive concepts herein taught, which may appear to 
those skilled in the pertinent art, will still fall within the spirit and scope of the present 
invention, as defined in the appended claims. 
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